JAVA程序员面试32问
面试真题
第一,谈谈fi
alfi
allyfi
alize的区别。fi
al修饰符(关键字)如果一个类被声明为fi
al,意味着它不能再派生出新的子类,不能作为父类被继承。因此一个类不能既被声明为abstract的,又被声明为fi
al的。将变量或方法声明为fi
al,可以保证它们在使用中不被改变。被声明为fi
al的变量必须在声明时给定初值,而在以后的引用中只能读取,不可修改。被声明为fi
al的方法也同样只能使用,不能重载fi
ally再异常处理时提供fi
ally块来执行任何清除操作。如果抛出一个异常,那么相匹配的catch子句就会执行,然后控制就会进入fi
ally块(如果有的话)。fi
alize方法名。Java技术允许使用fi
alize方法在垃圾收集器将对象从内存中清除出去之前做必要的清理工作。这个方法是由垃圾收集器在确定这个对象没有被引用时对这个对象调用的。它是在Object类中定义的,因此所有的类都继承了它。子类覆盖fi
alize方法以整理系统资源或者执行其他清理工作。fi
alize方法是在垃圾收集器删除对象之前对这个对象调用的。
第二,A
o
ymousI
erClass匿名内部类是否可以exte
ds继承其它类,是否可以impleme
ts实现i
terface接口匿名的内部类是没有名字的内部类。不能exte
ds继承其它类,但一个内部类可以作为一个接口,由另一个内部类实现。
第三,StaticNestedClass和I
erClass的不同,说得越多越好面试题有的很笼统。NestedClass(一般是C的说法),I
erClass一般是JAVA的说法。Java内部类与C嵌套类最大的不同就在于是否有指向外部的引用上。具体可见httpwwwfro
tfree
etarticlesservicesviewaspid704page1注:静态内部类(I
erClass)意味着1创建一个static内部类的对象,不需要一个外部类对象,2不能从一个static内部类的一个对象访问一个外部类对象
第四,和的区别。是位运算符。是布尔逻辑运算符。
第五,HashMap和Hashtable的区别。都属于Map接口的类,实现了将惟一键映射到特定的值上。HashMap类没有分类或者排序。它允许一个
ull键和多个
ull值。Hashtable类似于HashMap,但是不允许
ull键和
ull值。它也比HashMap慢,因为它是同步的。
第六,Collectio
和Collectio
s的区别。Collectio
s是个javautil下的类,它包含有各种有关集合操作的静态方法。Collectio
是个javautil下的接口,它是各种集合结构的父接口。
第七,什么时候用assert。
面试范本
f面试真题
断言是一个包含布尔表达式的语句,在执行这个语句时假定该表达式为true。如果表达式计算为false,r