1.以下代码的执行结果
String s1 = “helloworld”;
String s2 = “hello” + new Stirng(“world”);
System.out.println(s1 == s2);
分析:false,s1 == s2这比較的是两个对象的地址,而不是值。s2中存在new Stirng(“world”),该语句会新开辟一块内存来存放world字符串,因此,s1与s2的地址不同
2.以下说法正确的是(C)
A.class中的构造器不能省略
B.构造器必须和class同名,方法不能与class同名
C.构造器在一个对象被new时运行
D.一个class仅仅能有一个构造器
分析:class中的构造器不写,默认存在一个空构造器(无參);class中的方法是能够喝class同名的,仅仅只是非常少有人将class中的方法名定义成class名,方法和构造器唯一的差别就是构造器没有返回值;一个class可有多个构造器,通过參数的不同来加以区分。
3.java.lang.Exception类是继承自(Throwable类)的
分析:java.lang.Exception和java.lang.Ecxception都是继承自Throwable类的。Throwable类是全部java异常类的基类;java中的异常分为执行时异常(在程序编写的过程中难以察觉,仅仅有在程序实际执行的阶段才干发现,如:数组越界。空指针,分母为0等)和编译时异常(在程序编写的过程中就须要程序猿去处理。须要为其加入try/catch语句块,不加入则编译不通过,如:FileNotFoundException等)。
4.以下代码的执行结果
String []a = new String[10];
System.out.println(a[0]);
int []b = new int[10];
System.out.println(b[1]);
结果:
null
0
分析:第一句语句编译之后。会在栈中开辟一块内存来放字符串数组变量a,可是数组中的元素未初始化不论什么值,因此a[0]...a[9]均为默认值null;同理。int型数组中的元素也未初始化值。所以,b[0]...b[9]均为默认值0
5.以下代码的执行结果
class A{
public static void main(String args[]) { Thread t = new Thread() { public void run() { test(); } }; t.run(); System.out.print("Test"); } public static void test() { System.out.print("test"); }
}
结果:testTest
分析:首先实例化一个Thread对象并实现run方法(当一个线程開始运行时会默认去运行run方法),然后t.run()运行不过Thread对象中的run方法运行,而非开启一个线程。开启线程用t.start()方法。运行后打印test,最后是紧接着打印Test。
6.以下说法正确的是(AB)
A LinkedList继承自List
B HashSet继承自AbstractSet
C AbstractSet继承自Set
D WeakMap继承自HashMap
分析:见继承关系图
7.存在i使i+1<i的成立么?成立
分析:如果i为int类型,当i+1之后就超出int类型的数值范围(溢出)时。此时i+1就会变为负数,显然负数<正数
8.0.123的数据类型是(double)
分析:0.123当然是double了。0.123f或0.123F才是float
9.以下哪个是面向字符的输出流(A)
A.BufferedWriter
B.FileInputStream
C.ObjectInputStream
D.InputStreamReader
分析:java中的IO流分为字符(character)和字节(byte)流,面向字符的操作是以字符为单位对数据操作(read时将二进制转换为字符,write时将字符转换为二进制数据),面向字节的操作是以8位为一个单位对二进制的数据操作,不须要转换。
字符流都是以Reader/Writer结尾的,字节流都是以InputStream/OutputStream结尾的
详见Java Io流图:
10.谈谈对java中接口(interface)的理解
分析:接口是一类事物的属性和行为的抽象,是统一的抽象。既然是统一的,那就不能存在变量,因此,接口中的属性都是public static final的,行为都是public abstract的。
(1)接口表明了对外的公共的服务,因此接口中的属性和行为均为public的,谁都可使用;
(2)接口仅仅是告诉外界一个抽象来描写叙述能做什么。而详细里面的实现是不说明的,因此接口中的行为都是abstract的;
(3)接口中不包括详细的实现细节,因此不能实例化,也就没有实例变量的存在。
(4)接口中若存在仅可存在常量且必须初始化值。
11.Java中创建对象的有几种方法?各自是什么?
分析:共4种。例如以下:
(1)new语句来创建对象(调用构造函数)
(2)反射机制,调用Class类或Constructor类的newInstance()实例方法(调用构造函数)
(3)调用clone方法(是对内存上对象的clone,不调用构造函数)
(4)反序列化(调用ObjectInputStream对象的readObject()方法,是从文件里还原类对象)
12.以下的代码有问题么,若没问题。执行结果是?
public class NULL { public static void t(){ System.out.println("ttt"); } public static void main(String[] args) { ((NULL)null).t();
System.out.println(((NULL)null)); }}
结果:
ttt
null
分析:
(1)NULL不是java中的keyword或保留字。所以NULL能够为class名;
(2)null是java中的keyword。null值能够转换为不论什么的类型,可是转换为之后依旧为null(无效对象)值,此外。t函数为static。可直接类名.函数名来调用,因此,main函数中第二条语句能够正常运行。打印null;(若函数t不是static,程序就报错了)
13.谈下静态代码块,构造代码块。构造函数的运行顺序
静态代码块先运行,最后是构造代码块和构造函数运行(两者绑定,内部顺序为先构造代码块,后构造函数)
分析:当一个类载入完成之后,从父类到子类。从上到下。先要运行静态代码块,完成之后去运行main函数,若存在new对象的语句,则运行绑定的构造代码块和构造函数。
注意:静态代码块有且仅运行一次
14.以下代码的执行结果?
public class A{
public static void main(String[] args){
String str;
System.out.println(“” + str);
}
}
分析:以上代码不会编译通过,若str不被初始化,是不能打印输出的,java中的基本类型或对象均须要数据化,这不同于类的属性(成员变量)。
接下来再看以下的代码:
public class A{
static String str;
public static void main(String[] args){
System.out.println(“” + str);
}
}
分析:该代码就会编译通过。因为str为类的属性,因此打印出来为str的默认值null
15.Java中不存在引用传递。仅仅有值传递。
(不管是对象、基本类型或数组,在函数中均不能改变实际所在的地址。仅能改变当中的值)
16.Java中的String类能否够继承?不能够
分析:String类是final的,故不能够继承
17.Java中的构造器能够被override(重写)么?不能够
分析:java的构造器不能够继承,因此不能够override,但能够overload(重载)