什么是JVM
1.软层面的机器翻译:我们编写的java文件,编译后会被编译为class文件,之后会被类加载器加载到JVM里面,而JVM则把他翻译为计算机可以读懂的语言
2.内存管理(GC),Java对比与C,C++这些语言最大的优势就是可以实现GC内存回收。
Java运行时数据区
1.Java运行时数据区包括:
程序计数器,虚拟机栈,本地方法方法栈,方法区,堆
简述运行时数据区的各个组成:
1.程序计数器:记录当前运行的线程的内存地址和行码(因为是线程,有可能会被挂起,所以需要记录当前线程的内存地址和行码)
2.虚拟机栈:存储当前线程方法需要的数据(局部变量),指令(操作),返回(方法的return)
思考:当方法A里面调用了方法B的时候,他的压栈顺序问题:
关键点:先用完的先出栈,所以是方法B先出栈,方法A后出栈
3.本地方法栈:与虚拟机栈类似,不过他调用的是本地的方法
4.方法区:方法区存储的是:类信息,静态变量,常量,JIT
5.堆
简单的了解一下运行时的内存各个部分的线程安全问题:
了解Java内存模型:JMM
1.对比Java1.8前的版本和Java1.8版本
简要文字说明:1.8版本之前存在永久代,永久代存在的问题就是可能会产生内存泄漏的问题,1.8之后的版本使用meta space,meta space会自动的进行扩容操作。
2.思考为什么需要进行分代操作?
答.引用的对象生命周期不一样,所以需要进行分代
3.GC对不同的代使用的算法不一样
新生代:使用复制回收算法,因为新生代大部分的对象都需要被回收,存活下来的对象很少,所以在s1区复制保存存活的对象,其他区的新生代清楚对象
老年代:使用标记删除法,标记整理,老年代只是好少的数据需要删除,只需要标志被删除的对象就好了
什么样的对象会被GC(判断回收的算法)
1.引用计数法:
A引用了B,B的引用次数就加1,当引用次数为0的时候,就会被回收,但是存在相互引用的问题,永远不会被回收。
2.可达性分析
当从GCROOT找不到任何一个路径到达对象是,对象就会被回收。
什么对象可以成为GCROOT
关键是:对象是在当前状态不能被回收的
1.虚拟机栈的局部变量表里面引用的对象
2.方法区的常量,静态常量
不可达不一定会被回收
finalize()可能被重写,重新引用回去了。