Java面试精华:ArrayList vs Vector,HashMap vs Hashtable及多线程实现

需积分: 10 0 下载量 160 浏览量 更新于2024-07-23 收藏 118KB DOC 举报
在Java面试中,面试官经常关注以下几个关键知识点: 1. **作用域的理解**: - Java中的访问修饰符包括public、private、protected和默认(friendly,即不写时的默认情况)。它们的主要区别在于对象的可见性和访问范围: - public:在整个程序包(包括其他包)中可见,可以被任何类访问。 - protected:在同一包内和继承该包的类可见。 - default(friendly):仅在同一包内可见,非继承关系下的子类不可见。 - private:仅在声明它的类内部可见,外部无法直接访问。 2. **ArrayList和Vector的比较**: - Vector是线程安全的,提供了内置的同步机制,适合多线程环境。然而,它在插入和删除元素时效率较低,因为每次操作都需要同步。 - ArrayList是非线程安全的,但插入和删除操作更快,因为不需要同步,适用于对性能要求较高的单线程应用。 3. **HashMap和Hashtable的区别**: - 历史背景上,Hashtable是早期版本的Map实现,而HashMap是在Java 1.2引入的新特性。HashMap支持null键值对,而Hashtable不支持。 - 从线程安全性角度看,两者类似Vector和ArrayList的关系,Hashtable是同步的,HashMap是非同步的。 4. **字符类型(char)与中文字符存储**: - char类型可以存储中文字符,因为Java使用Unicode编码,每个字符占用16个字节,足以容纳大部分语言的字符,包括汉字。 5. **多线程实现方式**: - Java中实现多线程主要有两种方法: - 继承Thread类:创建自定义的线程类并重写run()方法。 - 实现Runnable接口:创建实现了Runnable接口的类,并将其实例作为Thread构造函数的参数。 6. **同步实现方法**: - 同步主要通过以下两种方式来实现: - synchronized关键字:用于修饰方法或代码块,确保同一时间只有一个线程可以访问。 - wait()和notify/notifyAll()方法:用于线程间的协作,控制等待和唤醒操作。 7. **类的继承顺序问题**: - 在Java中,子类的构造函数会按照一定的顺序执行,先调用父类的构造函数,然后再执行子类自己的构造函数。在给出的例子中,父类`FatherClass`的构造函数会在`ChildClass`的构造函数之前执行。 面试时,候选人应熟练掌握这些基础知识,能清晰地解释每个概念的细节及其在实际编程中的应用。同时,对于热点话题如容器类的优化选择、线程管理的最佳实践等,也需要有所了解。