Java面试常问题目

上传人:M****1 文档编号:550309551 上传时间:2024-01-08 格式:DOC 页数:25 大小:297.50KB
返回 下载 相关 举报
Java面试常问题目_第1页
第1页 / 共25页
Java面试常问题目_第2页
第2页 / 共25页
Java面试常问题目_第3页
第3页 / 共25页
Java面试常问题目_第4页
第4页 / 共25页
Java面试常问题目_第5页
第5页 / 共25页
点击查看更多>>
资源描述

《Java面试常问题目》由会员分享,可在线阅读,更多相关《Java面试常问题目(25页珍藏版)》请在金锄头文库上搜索。

1、wordJava类别问题1. String与StringBuilder、StringBuffer的区别如果要操作少量的数据用 = String单线程操作字符串缓冲区 下操作大量数据 = StringBuilder多线程操作字符串缓冲区 下操作大量数据 = StringBuffer2. Collection类,Collection包结构,与Collections的区别Collection是集类,包含List有序列表,Set无序集合以与Map双列集合Collection是集合类的上级接口,子接口主要有Set 和List、Map。 Collections是针对集合类的一个帮助类,提供了操作集合的工具

2、方法:一系列静态方法实现对各种集合的搜索、排序、线程安全化等操作。3. java哪些集合类是线程安全的vector:就比arraylist多了个同步化机制线程安全,因为效率较低,现在已经不太建议使用。在web应用中,特别是前台页面,往往效率页面响应速度是优先考虑的。statck:堆栈类,先进后出enumeration:枚举,相当于迭代器hashtable:就比hashmap多了个线程安全4. 线程安全是什么意思就是线程同步的意思,就是当一个程序对一个线程安全的方法或者语句进展访问的时候,其他的不能再对他进展操作了,必须等到这次访问完毕以后才能对这个线程安全的方法进展访问5. 九种根本数据类型的

3、大小,以与他们的封装类。java提供了一组根本数据类型,包括boolean, byte, char, short, int, long, float, double, void. 同时,java也提供了这些类型的封装类,分别为Boolean, Byte, Character, Short, Integer, Long, Float, Double, Void既然提供了根本类型,为什么还要使用封装类呢比如,如果想使用List来保存数值,由于List中只能添加对象,另外,有些情况下,我们也会编写诸如func(Object o)的这种方法6. Switch能否用string做参数在 Java 7之前

4、,switch 只能支持 byte、short、char、int或者其对应的封装类以与 Enum 类型。在 Java 7中,String支持被加上了。7. equals与=的区别。1.=是一个运算符。2.Equals如此是Object对象的方法,可以.点出来。8. Java的四种引用,强弱软虚,用到的场景1强引用,这是使用最普遍的引用。如果一个对象具有强引用,那就 类似于必不可少的生活用品,垃圾回收器绝不会回收它。当内存空 间不足,Java虚拟机宁愿抛出OutOfMemoryError错误,使程序异常终止,也不会靠随意回收具有强引用的对象来解决内存不足问题。2软引用,如果一个对象只具有软引用,

5、那就类似于可有可无的生活用品。如果内存空间足够,垃圾回收器就不会回收它,如果内存空间不足了,就会回收这些对象的内存。3弱引用,如果一个对象只具有弱引用,那就类似于可有可无的生活用品。 弱引用与软引用的区别在于:只具有弱引用的对象拥有更短暂的生命周期。在垃圾回收器线程扫描它 所管辖的内存区域的过程中,一旦发现了只具有弱引用的对象,不管当前内存空间足够与否,都会回收它的内存。4虚引用,虚引用顾名思义,就是形同虚设,与其他几种引用都不同,虚引用并不会决定对象的生命周期。如果一个对象仅持有虚引用,那么它就和没有任何引用一样,在任何时候都可能被垃圾回收。9. Hashcode的作用Hashcode这个方

6、法是用来鉴定2个对象是否相等的,hashcode方法一般用户不会去调用,比如在hashmap中,由于key是不可以重复的,他在判断key是不是重复的时候就判断了hashcode这个方法,而且也用到了equals方法。10. ArrayList、LinkedList、Vector的区别ArrayList,Vector底层是由数组实现,LinkedList底层是由双线链表实现,从底层的实现可以得出它们的性能问题,ArrayList,Vector插入速度相对较慢,查询速度相对较快,而LinkedList插入速度较快,而查询速度较慢。再者由于Vevtor使用了线程安全锁,所以ArrayList的运行效

7、率高于Vector。11. Map、Set、List、Queue、Stack的特点与用法Set集合类似于一个罐子,丢进Set集合里的多个对象之间没有明显的顺序。List集合代表元素有序、可重复的集合,集合中每个元素都有其对应的顺序索引。Stack是Vector提供的一个子类,用于模拟栈这种数据结构(LIFO后进先出)Queue用于模拟队列这种数据结构(先进先出 FIFO)。Map用于保存具有映射关系的数据,因此Map集合里保存着两组值12. HashMap和HashTable的区别Hashtable是基于陈旧的Dictionary类的,HashMap是Map接口的一个实现Hashtable的方

8、法是线程同步的,而HashMap的方法不是。只有HashMap可以让你将空值作为一个表的条目的key或value13. TreeMap、HashMap、LindedHashMap的区别Hashmap 是一个最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有很快的访问速度,遍历时,取得数据的顺序是完全随机的。LinkedHashMap保存了记录的插入顺序,在用Iterator遍历LinkedHashMap时,先得到的记录肯定是先插入的.也可以在构造时用带参数,按照应用次数排序TreeMap取出来的是排序后的键值对。但如果您要按自然顺序或自定义顺序遍历键,那么T

9、reeMap会更好。14. try catch finally,try里有return,finally还执行么a.不管有木有出现异常,finally块中代码都会执行b.当try和catch中有return时,finally仍然会执行c.finally是在return后面的表达式运算后执行的此时并没有返回运算后的值,而是先把要返回的值保存起来,管finally中的代码怎么样,返回的值都不会改变,任然是之前保存的值,所以函数返回值是在finally执行前确定的d.finally中最好不要包含return,否如此程序会提前退出,返回值不是try或catch中保存的返回值15. OOM你遇到过哪些情况

10、java.lang.OutOfMemoryError: Java heap space -java堆内存溢出,此种情况最常见,一般由于内存泄露或者堆的大小设置不当引起。java.lang.OutOfMemoryError: PermGen space -java永久代溢出,即方法区溢出了,一般出现于大量Class或者jsp页面,或者采用cglib等反射机制的情况,因为上述情况会产生大量的Class信息存储于方法区。java.lang.StackOverflowError - 不会抛OOM error,但也是比拟常见的Java内存溢出。JAVA虚拟机栈溢出,一般是由于程序中存在死循环或者深度递归

11、调用造成的,栈大小设置太小也会出现此种溢出。可以通过虚拟机参数-Xss来设置栈的大小。16. Java面向对象的三个特征与含义封装性:它是将类的一些敏感信息隐藏在类的类部,不让外界直接访问到继承性:子类通过一种方式来承受父类所有的公有的,受保护的成员变量和成员方法多态性:程序在运行的过程中,同一种类型在不同的条件下表现不同的结果17. Override和Overload的含义去区别方法的重写Overriding和重载Overloading是Java多态性的不同表现。重写Overriding是父类与子类之间多态性的一种表现,重载Overloading是一个类中多态性的一种表现。如果在子类中定义某

12、方法与其父类有一样的名称和参数,我们说该方法被重写 (Overriding)。子类的对象使用这个方法时,将调用子类中的定义,对它而言,父类中的定义如同被“屏蔽了。如果在一个类中定义了多个同名的方法,它们或有不同的参数个数或有不同的参数类型,如此称为方法的重载(Overloading)。Overloaded的方法是可以改变返回值的类型。18. Interface与abstract类的区别接口可以多重继承,抽象类不可以接口定义方法,不给实现;而抽象类可以实现局部方法接口中根本数据类型的数据成员,都默认为static和final,抽象类如此不是19. Static class 与non static

13、 class的区别内部静态类不需要有指向外部类的引用。但非静态内部类需要持有对外部类的引用。非静态内部类能够访问外部类的静态和非静态成员。静态类不能访问外部类的非静态成员。他只能访问外部类的静态成员。一个非静态内部类不能脱离外部类实体被创建,一个非静态内部类可以访问外部类的数据和方法,因为他就在外部类里面。20. java多态的实现原理.设计时多态:方法【重载】实现的多态.运行时多态:方法【重写】实现的多态21. 实现多线程的两种方法:Thread与Runable使用Runnable接口实际工作中,几乎所有的多线程应用都用实现Runnable这种方式。Runnable适合多个一样程序代码的线程

14、去处理同一资源的情况。把虚拟CPU(线程)同程序的代码、数据有效的别离,较好的表现了面向对象的设计思想。防止由于Java的单继承特性带来的局限性。也就是如果新建的类要继承其他类的话,因为JAVA中不支持多继承,就只能实现java.lang.Runnable接口。有利于程序的健壮性,代码能够被多个线程共享,代码与数据是独立的。继承Thread类不能再继承他类了。编写简单,可以直接操纵线程,无需使用Thread.currentThread()。22. 线程同步的方法:sychronized、lock、reentrantLock等sychronized是java中最根本同步互斥的手段,可以修饰代码块

15、,方法,类,在修饰代码块的时候需要一个reference对象作为锁的对象,在修饰方法的时候默认是当前对象作为锁的对象,在修饰类时候默认是当前类的Class对象作为锁的对象.ReentrantLock除了synchronized的功能,多了三个高级功能.等待可中断,在持有锁的线程长时间不释放锁的时候,等待的线程可以选择放弃等待公平锁, 按照申请锁的顺序来一次获得锁称为公平锁.synchronized的是非公平锁,ReentrantLock可以通过构造函数实现公平锁绑定多个Condition. 通过屡次newCondition可以获得多个Condition对象,可以简单的实现比拟复杂的线程同步的功能.通过await(),signal();23. Java锁的等级方法锁,synchronized标记的方法对象锁,在方法上加了synchronized的锁,或者synchronized(this的代码段类锁,在代码中的方法上加了static和synchronized的锁,因为在静态方法中加同步锁会锁住整个类24. 写出生产者消费者模式阻塞队列实现生产者消费者模式超级简单,它提供开箱即用支持阻塞的方法put()和take(),开发者不

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号