JAVA程序猿面试题汇总
(此话题将不断更新,请留意)
第一,谈谈final, finally, finalize的差别。
final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。finally是异常处理语句结构的一部分,表示总是运行。finalize是 Object类的一个方法,在垃圾收集器运行的时候会调用被回收对象的此方法,能够覆盖此方法提供垃圾收集时的其它资源回收,比如关闭文件等。
第二,Anonymous Inner Class (匿名内部类) 能否够extends(继承)其它类,能否够implements(实现)interface(接口)?
能够继承其它类或完毕其它接口,在swing编程中经常使用此方式。
第三,Static Nested Class 和 Inner Class的不同,说得越多越好(面试题有的非常笼统)。
Static Nested Class是被声明为静态(static)的内部类,它能够不依赖于外部类实例被实例化。而通常的内部类须要在外部类实例化后才干实例化。
第四,&和&&的差别。
&是位运算符,表示按位与运算,&&是逻辑运算符,表示逻辑与(and).
第五,HashMap和Hashtable的差别。
HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完毕了Map接口,主要差别在于HashMap同意空(null)键值(key),因为非线程安全,效率上可能高于Hashtable.
第六,Collection 和 Collections的差别。
Collection是集合类的上级接口,继承与他的接口主要有Set 和List.Collections是针对集合类的一个帮助类,他提供一系列静态方法实现对各种集合的搜索、排序、线程安全化等操作。
第七,什么时候用assert。
1.4新增keyword(语法),用于測试boolean表达式状态,可用于调试程序。用法 assert ,表示假设表达式为真(true),则以下的语句运行,否则抛出AssertionError。另外的使用方式assert < boolean表达式>:,表示假设表达式为真,后面的表达式忽略,否则后面表达式的值用于AssertionError的构建參数。注意编译时要添加-source 1.4 參数,否则报错。]运行时要添加 –ea參数,否则assert行被忽略
第八,GC是什么? 为什么要有GC?
GC是垃圾收集的意思(Gabage Collection),内存处理是编程人员easy出现故障的地方,忘记或者错误的内存回收会导致程序或系统的不稳定甚至崩溃,Java提供的GC功能能够自己主动监測对象是否超过作用域从而达到自己主动回收内存的目的,Java语言没有提供释放已分配内存的显示操作方法。
第九,String s = new String("xyz");创建了几个String Object?
两个
第十,Math.round(11.5)等於多少? Math.round(-11.5)等於多少?
Math.round(11.5)==12Math.round(-11.5)==-11round方法返回与參数最接近的长整数,參数加1/2后求其floor.
第十一,short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
short s1 = 1; s1 = s1 + 1; (s1+1运算结果是int型,须要强制转换类型)short s1 = 1; s1 += 1;(能够正确编译)
第十二,sleep() 和 wait() 有什么差别?
sleep是线程类(Thread)的方法,导致此线程暂停运行指定时间,给运行机会给其它线程,可是监控状态依旧保持,到时后会自己主动恢复。调用 sleep不会释放对象锁。wait是Object类的方法,对此对象调用wait方法导致本线程放弃对象锁,进入等待此对象的等待锁定池,仅仅有针对此对象发出notify方法(或notifyAll)后本线程才进入对象锁定池准备获得对象锁进入运行状态。
第十三,Java有没有goto?
没有,可是是保留keyword 非常十三的问题,假设哪个面试的问到这个问题,我劝你还是别进这家公司。
第十四,数组有没有length()这种方法? String有没有length()这种方法?
数组没有length()这种方法,有length的属性。
String有有length()这种方法。
第十五,Overload和Override的差别。Overloaded的方法能否够改变返回值的类型?
方法的重写Overriding和重载Overloading是Java多态性的不同表现。重写Overriding是父类与子类之间多态性的一种表现, 重载Overloading是一个类中多态性的一种表现。假设在子类中定义某方法与其父类有同样的名称和參数,我们说该方法被重写 (Overriding)。子类的对象使用这种方法时,将调用子类中的定义,对它而言,父类中的定义如同被“屏蔽”了。假设在一个类中定义了多个同名的方法,它们或有不同的參数个数或有不同的參数类型,则称为方法的重载(Overloading)。Overloaded的方法是能够改变返回值的类型。
第十六,Set里的元素是不能反复的,那么用什么方法来区分反复与否呢? 是用==还是equals()? 它们有何差别?
Set里的元素是不能反复的,那么用iterator()方法来区分反复与否。equals()是判读两个Set是否相等。
equals()和==方法决定引用值是否指向同一对象equals()在类中被覆盖,为的是当两个分离的对象的内容和类型相配的话,返回真值。
第十七,给我一个你最常见到的runtime exception。
參考例如以下:
ArithmeticException,
ArrayStoreException,
BufferOverflowException,
BufferUnderflowException,
CannotRedoException,
CannotUndoException,
ClassCastException,
CMMException,
ConcurrentModificationException,
DOMException,
EmptyStackException,
IllegalArgumentException,
IllegalMonitorStateException,
IllegalPathStateException,
IllegalStateException,
ImagingOpException,
IndexOutOfBoundsException,
MissingResourceException,
NegativeArraySizeException,
NoSuchElementException,
NullPointerException,
ProfileDataException,
ProviderException,
RasterFormatException,
SecurityException,
SystemException,
UndeclaredThrowableException,
UnmodifiableSetException,
UnsupportedOperationException
第十八,error和exception有什么差别?
error 表示恢复不是不可能但非常困难的情况下的一种严重问题。比方说内存溢出。不可能指望程序能处理这种情况。
exception 表示一种设计或实现问题。也就是说,它表示假设程序执行正常,从不会发生的情况。
第十九,List, Set, Map是否继承自Collection接口?
List,Set是
Map不是
第二十,abstract class和interface有什么差别?
声明方法的存在而不去实现它的类被叫做抽象类(abstract class),它用于要创建一个体现某些基本行为的类,并为该类声明方法,但不能在该类中实现该类的情况。不能创建abstract 类的实例。然而能够创建一个变量,其类型是一个抽象类,并让它指向详细子类的一个实例。不能有抽象构造函数或抽象静态方法。Abstract 类的子类为它们父类中的全部抽象方法提供实现,否则它们也是抽象类为。取而代之,在子类中实现该方法。知道其行为的其他类能够在类中实现这些方法。
接口(interface)是抽象类的变体。在接口中,全部方法都是抽象的。多继承性可通过实现这种接口而获得。接口中的全部方法都是抽象的,没有一个 有程序体。接口仅仅能够定义static final成员变量。接口的实现与子类类似,除了该实现类不能从接口定义中继承行为。当类实现特殊接口时,它定义(即将程序体给予)全部这种接口的方法。然后,它能够在实现了该接口的类的不论什么对象上调用接口的方法。因为有抽象类,它同意使用接口名作为引用变量的类型。通常的动态联编将生效。引用能够转换到接口类型或从接口类型转换,instanceof 运算符能够用来决定某对象的类是否实现了接口。
第二十一,abstract的method是否可同一时候是static,是否可同一时候是native,是否可同一时候是synchronized?
都不能
第二十二,接口是否可继承接口? 抽象类是否可实现(implements)接口? 抽象类是否可继承实体类(concrete class)?
接口能够继承接口。抽象类能够实现(implements)接口,抽象类是否可继承实体类,但前提是实体类必须有明白的构造函数。
第二十三,启动一个线程是用run()还是start()?
启动一个线程是调用start()方法,使线程所代表的虚拟处理机处于可执行状态,这意味着它能够由JVM调度并执行。这并不意味着线程就会马上执行。run()方法能够产生必须退出的标志来停止一个线程。
第二十四,构造器Constructor是否可被override?
构造器Constructor不能被继承,因此不能重写Overriding,但能够被重载Overloading。
第二十五,能否够继承String类?
String类是final类故不能够继承。
第二十六,当一个线程进入一个对象的一个synchronized方法后,其他线程是否可进入此对象的其他方法?
不能,一个对象的一个synchronized方法仅仅能由一个线程訪问。
第二十七,try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被运行,什么时候被运行,在return前还是后?
会运行,在return前运行。
第二十八,编程题: 用最有效率的方法算出2乘以8等於几?
有C背景的程序猿特别喜欢问这样的问题。
2 < < 3
第二十九,两个对象值同样(x.equals(y) == true),但却可有不同的hash code,这句话对不正确?
不正确,有同样的hash code。
第三十,当一个对象被当作參数传递到一个方法后,此方法可改变这个对象的属性,并可返回变化后的结果,那么这里究竟是值传递还是引用传递?
是值传递。Java 编程语言仅仅由值传递參数。当一个对象实例作为一个參数被传递到方法中时,參数的值就是对该对象的引用。对象的内容能够在被调用的方法中改变,但对象的引用是永远不会改变的。
第三十一,swtich能否作用在byte上,能否作用在long上,能否作用在String上?
switch(expr1)中,expr1是一个整数表达式。因此传递给 switch 和 case 语句的參数应该是 int、 short、 char 或者 byte。long,string 都不能作用于swtich。
第三十二,编程题: 写一个Singleton出来。
Singleton模式主要作用是保证在Java应用程序中,一个类Class仅仅有一个实例存在。
一般Singleton模式通常有几种种形式:
第一种形式: 定义一个类,它的构造函数为private的,它有一个static的private的该类变量,在类初始化时实例话,通过一个public的getInstance方法获取对它的引用,继而调用当中的方法。
public class Singleton {
private Singleton(){}
//在自己内部定义自己一个实例,是不是非常奇怪?
//注意这是private 仅仅供内部调用
private static Singleton instance = new Singleton();
//这里提供了一个供外部訪问本class的静态方法,能够直接訪问
public static Singleton getInstance() {
return instance;
}
}
另外一种形式:
public class Singleton {
private static Singleton instance = null;
public static synchronized Singleton getInstance() {
//这种方法比上面有所改进,不用每次都进行生成对象,仅仅是第一次
//使用时生成实例,提高了效率!
if (instance==null)
instance=new Singleton();
return instance; }
}
其它形式:
定义一个类,它的构造函数为private的,全部方法为static的。
一般觉得第一种形式要更加安全些
当中也存在一些问题,以下补充一下.希望大家继续补充
1.最好介绍一下final修饰变量的情形(分开说明基本类型变量和引用类型变量)。
2.不知道怎样描写叙述比較好,匿名内部类本身是一个实现了特定接口或继承了其它类的类。
3.非静态类不能有static的方法。參考一下java collections framework的代码,还能说出非常多东西来。
4.&既是位运算符,也是逻辑操作符。
&和&&都是逻辑运算符,它们的差别是,&&进行短路计算。
6.能够补充一下,參考文档。
11.说一下详细的原因可能更好。
13.java有goto这个keyword,只是还没有使用。
15.overload和多态没有不论什么关系。多态是面向对象的基本特征,是和继承、overriding相关的。原来以为把overload当作多态的一种是从C++来的,后来翻了基本c++的经典的书,也强调多态仅仅是和继承,虚函数,overriding相关,所以不知道这个错误思想从哪来的了.
16.public interface Set <E>extends Collection <E>一个不包括反复元素的 collection。更确切地讲,set 不包括满足 e1.equals(e2) 的元素对 e1 和 e2,而且最多包括一个 null 元素。正如其名称所暗示的,此接口模仿了数学上的 set 抽象。
看文档就是了.
22."抽象类是否可继承实体类,但前提是实体类必须有明白的构造函数。"什么意思?谁规定的?
27.这个比較复杂,比如
public class Main {
public static void main(String[] args) {
System.out.println(test());
}
public static boolean test() {
boolean b = false;
try {
return b = 4 > 3;
} finally {
System.out.println(b);
//return false;
}
}
}
这个样例中能够看出,return后面的表达式已经计算了,感觉return语句这里被挂起了,假设finally中没有return,这个return就返回.
假设finally也有return,那么就是finally中的return返回了.
29.碰上不守规矩的程序猿谁也没办法.
31.还有枚举呢