java面试题整理( 二 )


十四.集合使用
java面试题整理文章插图
十五.Set 里的元素是不能重复的 , 那么用什么方法来区分重复与否呢?是用 == 还是 equals()?它们有何区别?
equals
十六.Comparable 和 Comparator 接口是干什么的?列出它们的区别?
如果想对一个对象进行排序 , 可以有两种方式 。 一个是这个对象实现comparable接口、另一个是单独写一个类 , 这个类实现Comprator接口 。 相当于一个在需要排序的内部实现 , 一个可以在外部实现 。
十七.Collection 和 Collections 的区别 。
Collection是集合的接口、Collections是操作集合的一个工具类
十八.java类加载过程?
1.加载->链接(验证、准备、解析)->初始化
2.加载:加载二进制流、静态结构转化为方法区和数据结构、生成类对象
十九.jvm加载class的原理和机制?
1.java通过双亲委派机制加载类 , 这样的好处是安全 。
2.有三个类加载器:系统类加载器(加载java的系统类)扩展类加载器(继承和实现的类)程序类加载器(程序员自定义的类)
二十.java内存分配?
堆:存储java的实例对象
栈:线程私有 , 存储局部变量表 , 动态链接
方法区:线程共享的 , 存储class二级制文件 。 包含类信息、常量池、静态变量
程序计数器:线程私有的 , 记录着程序运行的位置
本地方法栈:存储java本地方法信息
二十一.GC是什么?
是java的内存回收机制 , 通过算法判断对象是否为垃圾对象来进行回收 。 如果判断对象是垃圾对象呢 , 有两种算法:一种是引用计数法 , 当对象被引用一次时计数加一 。 当引用计数的次数为零的时候就表示对象无用了 。 但是这种算法有一个问题 , 就是当对象循环引用时无法做出正确的判断 。 还有一种算法是可达性分析:把对象看作一棵树 , 看对象是否可达 。
回收过程:1.分为下面四个区:eden、s1、s2、old
2.对象先放入eden中 , 满了就放入s1-》s1满了放入s2 , eden和s1清空-》s2满了将对象放入old中 , 然后s1和s2互换-》old满了进行老年代的回收
二十二.Java 中会存在内存泄漏吗
数据库连接、网络连接
二十三.深拷贝和浅拷贝
深拷贝是拷贝对象的属性 , 如果原对象有引用的属性则修改引用属性不会引起拷贝对象的变化 。
二十四.System.gc和Runtime.gc
功能一样 , 不建议使用 。
二十五.finalize() 方法什么时候被调用?析构函数 (finalization) 的目的是什么?
对象回收前会调用finalize方法、析构函数与构造函数相反 , 就是释放资源 。
二十六.什么是分布式垃圾回收(DGC)?它是如何工作的?
跨虚拟机的远程对象引用 , 引用有租期 。 定时发送租约 。
二十七.串行(serial)收集器和吞吐量(throughput)收集器的区别是什么?
串行针对小应用、吞吐量针对大数据量
二十八.Minor GC 和 Major GC
minorGC是新生代的gc、Major是老年代的gc
二十九.JVM 的永久代中会发生垃圾回收么?
不会 , 如果满了会直接抛出异常 。
三十.双亲委派机制?
会递归它的父类加载器进行加载 , 好处:放置重复加载、安全 。
三十一.Synchronized 用过吗 , 其原理是什么?
重量解锁 , 可以修饰方法 , 也可以修饰代码块 。 是通过监视器实现的 。 一个监视器的锁只能被一个线程持有 , 这样保证了同一时刻只有一个线程执行这段代码 。 进入监视器时enter、退出时exit、并且监视器有一个计数器 。 这个线程获得了这个锁计数器就加一 , 同一个线程再次获得这个锁时就再加一 。 最后这个计数器为零时表明其他线程可以访问这段代码了 。
三十二.什么是可重入性?


推荐阅读