JVM
-
JVM的位置
-
JVM的体系结构
-
类加载器
-
沙箱安全机制
-
Java1.1增加,给定权限后能够使用
-
字节码校验器:确保java类文件尊循Java语言规范。这样可以帮助Java程序实现内存保护。但并不是所有的类文件都会经过字节码校验, 比如核心类
-
类装载器:在3个方面对Java沙箱起作用
-
- 守护了被信任的类库边界
虚拟机为不同的加载器载入的类提供了不同的命名空间,命名空间由一系列唯一的名称组成,每一个被装载的类将有一个名字,这个命名空间是由Java虚拟机为每一个类装载器维护的,他们之间甚至不可见。
-
-
native关键字
-
PC寄存器
-
方法区
被所有线程共享
静态变量、常量、类信息(构造方法、接口定义)、运行时的常量池存在方法区中,但实例变量存在堆内存中,和方法区无关
static final Class 常量池
-
栈
- 数据结构
- 程序=数据结构+算法:持续学习~
- 程序=框架+业务逻辑:吃饭~
- Sun公司 HotSpot
- BEA公司 JRockit
- j9vm
我们学习的都是HotSpot
堆
-
类加载器读取了类文件后,一般会把什么东西放在堆中?
- 类,方法,常量,变量,保存我们所有引用类型的真实对象;
-
堆内存还要细分三个区域:
- 新生区(伊甸园区)满了触发重GC Full GC:
- 类:诞生和成长的地方,甚至死亡
- 伊甸园Eden Space:所有的对象都是在这 new出来的 满了触发轻GC,幸存留在幸存区
- 幸存区0区、幸存1区。
- 99%对象都是临时对象!!!
- 养老区:
- 永久区:这个区域常驻内存的,用来存放JDK自身携带的Class对象。Interface元数据,存储的是Java运行时的一些环境或信息,这个区域不存在垃圾回收!关闭vm虚拟机就会释放这个区域内存
一个启动类,加载了大量的第三方jar包,Tomcat部署了太多的应用,大量动态生成的反射类。不断被加载。直到内存满,就会出现OOM;- jdk1.6之前:永久代,常量池是在方法区
- jdk1.7:永久代,但是慢慢的退化了,
去永久代
,常量池在堆中 - Jdk1.8之后:无永久代,常量池在元空间
GC垃圾回收,主要是在伊甸园区和养老区
假设内存满了,OOM,堆内存不够
JDK8以后,永久存储区改名为元空间
默认情况,分配的总内存是电脑的1/4,而初始化的内存:1/64
OOM解决:
- 新生区(伊甸园区)满了触发重GC Full GC:
GC垃圾回收
G C
JVM在进行GC时,并不是对三个区域统一回收。大部分时候,回收都是新生代
- 新生代
- 幸存区(from,to)
- 老年区
GC两种类:轻GC(普通),重GC(全局)
题目:
- JVM的内存模型和分区,详细到每个区存放什么?
- 堆里面的分区有哪些?Eden,from,to,老年区,说说他们的特点!
- GC的算法有哪些?标记清除法,标记整理法,复制算法,引用计数器,怎么用的?
- 轻GC和重GC分别在什么时候发生?
引用计数法
复制算法
-
幸存区:谁空谁是to,每次GC都会将Eden中活的对象移到幸存区中:一旦Eden区被GC后,就回事空的
-
当一个对象经历了15次GC,都还没有死
-
-XX:MaxTenuringThreshold=9999,通过这个参数可以设定进入老年代的时间
-
好处:没有内存的碎片
-
坏处:浪费了内存空间:多了一半空间永远是空“to”,假设对象100%存活(极端情况)
复制算法使用场景:对象存活度较低;新生区
标记清除算法
- 优点:不需要额外的空间
- 缺点:两次扫描,严重浪费时间,会产生内存碎片
总结
思考:难道没有最优算法?
答案:没有最好的算法,只有最合适的算法---->GC:分代收集算法
年轻代:
- 存活率低
- 复制算法
老年代:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。