Java高频面试题之虚拟机篇

1、什么是字节码?采用字节码的好处是什么?

编译器(javac)将jave源文件(.java)编译成为字节码文件(.class),可以做到一次编译到处运行,windows上编好的class文件,可以直接在linux上运行,通过这种方式做到跨平台,不过java的跨平台有一个前提条件,就是不同的作系统上安装的JDK或JRE是不一样的,虽然字节码是通用的,但是需要把字节码解释成各个操作系统的机器码是需要不同的解释器的,所以针对各个操作系统需要有各自的JDK或JRE。
采用字节码的好处,一方面实现了跨平台,另外一方面也提高了代码执行的性能.编译器在编译源代码时可以做一些偏译期的优化,比如锁消除、标量替换、方法内联等。

2、Java中的异常体系是怎样的

● Java中的所有异常都来自顶级父类Throwable。
● Throwable下有两个子类Exception和Error。
● Error表示非常严重的措误,比Java.lang.StackverFlowEro和ava.lang.0utOfMemoryError,通常这些错误出现时,仅仅想靠程序自己是解决不了的,可能是虚拟机、磁盘、操作系统层面出现的问题了,所以通常也不建议在代码中去捕获这些Error,因为捕获的意义不大,因为程序可能已经根本运行不了了。
● Excpetion麦示异常,表示程序出现Exception时,是可以靠程序自己来解决的,比如NuPointerExeption、IllegalAccessException等,我们可以获这些异常来做特处理。
● Exception的子类通常又可以分为RuntimeException和非RuntimeException两类
● RunTimetxeption表示运行期异常,表示这个异常是在代码运行过程中抛出的,这些异常是非检查异常,程序中可以选择捕获处理,也可以不处理,这些异常一般是由程序逻辑错误引起的,程序应该从逻角度尽可能避免这类异常的发生,比如NulPointerException、Index0utOfBoundsException等。
● 非RuntimeExceoton表示非运行期异常,也就是我们常说的检查时异常,是必须进行处理的异常,如果不外理,程序就不能检查通过,如IOExcption、SQLExeptin等以及用户自定义的Exception异常。

3、Java中有哪些类加载器

JDK自带有三个类加载器: bootstrapClassLoader、ExtClassLoader、AppClassLoader。
● BootStrapClassLoader是ExtClassLoader的父类加载器,默认负责加载%JAVA HOME%lib下的iar包和class文件
● ExtClassLoader是AppClassLoader的父类加载器,负责加载%JAVA HOME%/lib/ext文件夹下的iar包和class类.
● AppClassLoader是自定义类加载器的父类,负责加载classpath下的类文件。

4、说说类加载器双亲委派模型

JVM中存在三个默认的类加载器:
1,BootstrapClassLoader
2,ExtClassLoader
3,AppClassLoader
AppClassLoader的父加载器是ExtClassLoader,ExtClassLoader的父加载器是BootstrapClassLoader.
NVM在加载一个类时,会调用AppClassloader的loadClas方法来加这类,不过在这方法中,会先使用ExClasloader的oadClass万法来加载类,同样ExClasLloadei的oadClass方法中会先使用BootstrapClasloader来加载类,如果Bootstraolassloader加载到了就直接功,如果BootstrapClassoader没有加费到,那么ExtClassL.oader就会自己尝试加载该类,如果没有加载到,那么则会由AppClassLoader来加载这个类。
所以,双亲委派指得是,JVM在加载类时,会委派给Ext和Bootstrap进行加载,如果没加载到才由自己进行加载.

5、GC如何判断对象可以被回收

● 引用计数法:每个对象有一个引用计数属性,新增一个引用时计数加1,引用释放时计数减1,计数为0时可以回收,
● 可达性分析法: 从 GC Roots 开始向下搜索,搜索所走过的路径称为引用链。当一个对象到 GC Roots 没有任何引用链相连时,则证明此对象是不可用的,那么虚拟机就判断是可回收对象。
引用计数法,可能会出现A引用了 B,B 又引用了 A,这时候就算他们都不再使用了,但因为相互引用 计数器=1 永远无法被回收。
GC Roots的对象有:
● 虚拟机栈(栈帧中的本地变量表)中引用的对象
● 方法区中类静态属性引用的对象
● 方法区中常量引用的对象
● 本地方法栈中]NI(即一般说的Native方法)用的对象

可达性算法中的不可达对象并不是立即死亡的,对象拥有一次自我拯救的机会。对象被系统宣告死亡至少要经历两次标记过程:第一次是经过可达性分析发现没有与GC Roots相连接的引用链,第二次是在由虚拟机自动建立的Finalizer队列中判断是否需要执行finalize0方法。
当对象变成(GC Roots)不可达时,GC会判断该对象是否覆盖了finalize方法,若未覆盖,则直接将其回收。否则,若对象未执行过finalize方法,将其放入F-Queue队列,由一低优先级线程执行该队列中对象的finalize方法。执行finalize方法完毕后,GC会再次判断该对象是否可达,若不可达,则进行回收,否则,对象”复活“
每个对象只能触发一次finalize()方法
由于finalize()方法运行代价高昂,不确定性大,无法保证各个对象的调用顺序,不推荐使用,建议遗忘它。

6、JVM中哪些是线程共享区,哪些是线程隔离区

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值