前言
这是一篇打算持续更新的文章。
最近在刷牛课网上的专项练习——JAVA部分。感觉对复习一些基础知识、原先模糊的部分还是很有帮助的。为了加深印象和方便日后复习。在这里记录下一些做错的题和虽然做对但觉得有必要记录下的题目。
1.对下列代码描述正确的是:答案A,错选D
- 能编译通过,并正确运行
- 因为使用了未初始化的变量,所以不能编译通过
- 以错误的方式访问了静态方法
- 能编译通过,但因变量为null,不能正常运行
class Test {
public static void hello() {
System.out.println("hello");
}
}
public class MyApplication {
public static void main(String[] args) {
Test test = null;
test.hello();
}
}
分析:这里如果hello()是个普通实例方法的话就选D了,可是hello()是静态方法,不需要对象也可以调用。记住就是了。
2.以下代码的输出结果是?
public class B {
public static B t1 = new B();
public static B t2 = new B();
{
System.out.println("construct block");
}
static
{
System.out.println("static block");
}
public static void main(String[] args) {
B t = new B();
}
}
答案:
construct block
construct block
static block
construct block
分析:这道题猛地一看可能会new了三个对象,那肯定先输出一个静态块后跟三个构造块了。可事情并不是这么绝对,这里的t1,t2两个对象也是静态的,他们在静态块之前执行。所以出现了先有两个构造块,再有一个静态块。最后的构造块是main里的对象t初始化时输出的。
3.若有定义语句: int a=10 ; double b=3.14 ;则表达式 ’A’+a+b 值的类型是()
答案:double。这其实是一道考察向上转型的题。数据类型上double > int > char。所以最后转换为double。
如果“A”+a+b则应该为String类型。
4.下列程序的输出为:编译错误。
class Base{
public Base(String s){
System.out.print("B");
}
}
public class Derived extends Base{
public Derived (String s) {
System.out.print("D");
}
public static void main(String[] args){
new Derived("C");
}
}
分析:由于Derived继承了Base类,生成Derived对象时也要先调用Base的构造方法。Derived只有唯一的构造方法,且在这个构造方法中没有显示地调用父类构造方法,所以会调用默认构造方法,而base又没有默认构造方法,所以会出错。
5.关于多线程的题
对于一个线程类(自己写的继承自Thread).如果直接调用run(),那么是和调用普通方法是一样的,并不会使线程运行起来,要调用start()才行。
注意这个陷阱,有个题就这么把我坑了。
6.变量的存储区域
下列java代码中的变量a,b,c分布在内存的那个区域?
class A {
private String a = "aa";
public boolean methodB() {
String b = "bb";
final String c = "cc";
}
}
答案:堆区,栈区,栈区
分析:首先我们知道‘虚拟机栈’就是为了给方法调用时存储‘局部变量表’等的,所以b,c无疑是位于栈区的。而堆区是存储对象的,当然对像的属性a,也位于堆区。
7.创建二维数组的写法
正确的是:
float f[][] = new float[6][6];
float []f[] = new float[6][6];
float f[][] = new float[][6];
float [][]f = new float[6][6];
float [][]f = new float[6][];
答案:ABDE。
解析:声明时f、[]、[]可以任意组合。new中必须写行数,列数随意。
8.forward和redirect的区别。
forward是服务端动作,redirect是客户端动作;