谈谈你对jvm的理解?
Java虚拟机,Java文件编译成.Class文件后,在jvm中运行
jre包含jvm
jvm的位置?
运行在操作系统上(windoes,linux。。。),用c语言写的
jvm的体系结构?
java—>.class—>类装载器(classloader)–>jvm(运行时数据区,方法区,Java栈,本地方法栈(native method stack),堆(heap),程序计数器)–>本地方法接口以及执行引擎
其中栈,本地方法栈和程序计数器不会有垃圾回收
方法区:
方法区是被所有线程共享,所有字段和方法字节码,以及一些特殊方法,如构造函数,接口代码也在此定义,简单说,所有定义的方法的信息都保存在该区域,此区域属于共享区间;
静态变量、常量、类信息(构造方法、接口定义)、运行时的常量池存在方法区中,但是实例变量存在堆内存中,和方法区无关
Java8虚拟机和之前的变化?
什么是oom(内存溢出),什么是栈溢出(staticoverflow)?怎么分析?
Jvm的常用调优参数有哪些?
jvm调优主要是栈和堆
内存快照如何抓取?怎么分析dump文件?
谈谈对类加载器的理解?
作用:加载class文件
- 虚拟机自带的加载器
- 启动类(根)加载器
- 扩展类加载器
- 应用程序加载器
应用程序加载器—>扩展类加载器—>应用程序加载器
双亲委派机制?
作用:保证安全
JVM中提供了三层的ClassLoader:
-
Bootstrap classLoader:主要负责加载核心的类库(java.lang.*等),构造ExtClassLoader和APPClassLoader。
-
ExtClassLoader:主要负责加载jre/lib/ext目录下的一些扩展的jar。
-
AppClassLoader:主要负责加载应用程序的主函数类
- 类加载器收到类加载的请求
- 将这个请求向上委托给父类加载器去完成,直到启动类加载器
- 启动类加载器检查是否能够加载当前类,能就加载技术,否则抛出异常通知子加载器进行加载
- 重复步骤3
沙箱安全机制?
参考地址:https://blog.csdn.net/weixin_40927436/article/details/104828455
pc寄存器(程序计数器)?
- 每个线程启动的时候,都会创建一个PC寄存器。PC寄存器里保存有当前正在执行的JVM指令的地址。 每一个线程都有它自己的PC寄存器,也是该线程启动时创建的,是线程私有的。
- 保存下一条将要执行的指令地址的寄存器是 :PC寄存器。PC寄存器的内容总是指向下一条将被执行指令的地址,这里的地址可以是一个本地指针,也可以是在方法区中相对应于该方法起始指令的偏移量。
- 每个线程都有一个程序计数器,是线程私有的,就是一个指针,指向方法区中的方法字节码(用来存储指向下一条指令的地址,也即将要执行的指令代码),由执行引擎读取下一条指令,是一个非常小的内存空间,几乎可以忽略不记。
栈和堆?
栈:存放对象的引用+八大数据类型+实例方法
栈运行原理:栈帧
栈是线程级的,一个线程有一个占内存
堆:存放对象的具体内容
一个jvm只有一个堆内存,堆内存大小可以调节
类加载器读取类文件后,一般会把类,方法,常量变量放在堆中,一般会保存我们引用类型的真实对象
新生区和老人区、永久区?
堆内存一般分为新生区和老人区、永久区
一个启动类加载类太多第三方jar包,tomcate部署了太多应用,大量动态生成反射类,不断被加载,直到内存占满就会出现OOM
永久区:原来存放jdk自带的class对象,接口源数据,存储的是java运行时的一些环境,这个区域是常驻内存的,这个区域不存在垃圾回收,关闭jvm虚拟机就会释放这个地方的内存
新生区:诞生类,成长的地方(伊甸园区,幸存者区(0区,1区))
三种jvm?
sum公司的hotspot、BEA公司的jrockit、IBM公司的J9VM
堆内存调优?
gc垃圾回收器(常用算法)?
jmm?
native关键字?
一旦带了native关键字的,说明java的作用范围达不到了,回去调用底层c语言的库,会进入本地方法栈