Java垃圾回收机制(2)- Java的内存分布
来源:互联网 发布:572-393的简便算法 编辑:程序博客网 时间:2024/06/05 10:05
Java的内存分布
在JVM中,内存是按照分代进行组织的。
其中,堆内存分为年轻代和年老代,非堆内存主要是Permanent(永久代)区域,主要用于存储一些类的元数据,常量池等信息。而年轻代又分为两种,一种是Eden区域,另外一种是两个大小对等的Survivor区域。之所以将Java内存按照分代进行组织,主要是基于这样一个“弱假设” - 大多数对象都在年轻时候死亡。同时,将内存按照分代进行组织,使得我们可以在不同的分代上使用不同的垃圾回收算法,使得整个内存的垃圾回收更加有效。
年轻代(Young Generation)
1.所有新生成的对象首先都是放在年轻代的。年轻代的目标就是尽可能快速的收集掉那些生命周期短的对象。
2.新生代内存按照8:1:1的比例分为一个eden区和两个survivor(survivor0,survivor1)区。一个Eden区,两个 Survivor区(一般而言)。大部分对象在Eden区中生成。回收时先将eden区存活对象复制到一个survivor0区,然后清空eden区,当这个survivor0区也存放满了时,则将eden区和survivor0区存活对象复制到另一个survivor1区,然后清空eden和这个survivor0区,此时survivor0区是空的,然后将survivor0区和survivor1区交换,即保持survivor1区为空, 如此往复。
3.当survivor1区不足以存放 eden和survivor0的存活对象时,就将存活对象直接存放到老年代。若是老年代也满了就会触发一次Full GC,也就是新生代、老年代都进行回收
4.新生代发生的GC也叫做Minor GC,MinorGC发生频率比较高(不一定等Eden区满了才触发)
年老代(Old Generation)
1.在年轻代中经历了N次垃圾回收后仍然存活的对象,就会被放到年老代中。因此,可以认为年老代中存放的都是一些生命周期较长的对象。
2.内存比新生代也大很多(大概比例是1:2),当老年代内存满时触发Major GC即Full GC,Full GC发生频率比较低,老年代对象存活时间比较长,存活率标记高。
持久代(Permanent Generation)
用于存放静态文件,如Java类、方法等。持久代对垃圾回收没有显著影响,但是有些应用可能动态生成或者调用一些class,例如Hibernate 等,在这种时候需要设置一个比较大的持久代空间来存放这些运行过程中新增的类。
- Java垃圾回收机制(2)- Java的内存分布
- java的内存垃圾回收机制
- Java的内存和垃圾回收机制
- java内存管理机制+垃圾回收机制(*****)
- JAVA内存垃圾回收机制
- JAVA内存垃圾回收机制
- JAVA内存垃圾回收机制
- java内存垃圾回收机制
- Java内存垃圾回收机制
- Java内存回收 垃圾回收机制
- java内存回收---垃圾回收机制
- Java内存回收(垃圾回收)机制总结
- Java的内存回收——垃圾回收机制
- Java内存管理(二)Java垃圾回收机制
- .Java的垃圾回收机制(GC)
- Java的垃圾回收机制(未完)
- GC(Java的垃圾回收机制)
- java的垃圾回收(GC)机制
- 【sort-list】
- ubuntu 报错: The system is running in low-graphics mode
- 背包问题 3 多重背包 解题报告
- 初识JWT(java web token)
- PyCharm配置mongo插件
- Java垃圾回收机制(2)- Java的内存分布
- 视频检测之:利用结构稀疏性(结构稀疏范数)进行RPCA分析
- bzoj4996: [Usaco2017 Feb]Why Did the Cow Cross the Road II
- 20. Valid Parentheses
- Ubuntu & GitLab CI & Docker & ASP.NET Core 2.0 自动化发布和部署(1)
- 关于Thinkpad E540 电脑更换固态硬盘的相关问题
- BZOJ[3038]上帝造题的7分钟2 树状数组+并查集
- KMP算法详解
- Accelerated C++ 15 Revisiting character pictures