【Java】备忘录

Java中的分代垃圾回收算法

Java中的分代垃圾回收算法是针对不同生命周期的对象采取不同的回收策略,主要将堆内存分为新生代和老年代两部分,分别采用不同的回收算法。

1. 新生代(Young Generation)的垃圾回收算法:

新生代主要存放新创建的对象,其特点是对象的生命周期较短。因此,针对新生代的垃圾回收算法主要考虑了尽快回收新生代中的短命对象,以提高内存利用率和降低垃圾回收的成本。

1.1 复制算法(Copying Algorithm):
  • 新生代采用的主要垃圾回收算法是复制算法,也称为标记-复制算法。这种算法将新生代的内存空间划分为两个相等的区域:Eden区、From区和To区。当对象被分配到Eden区时,当Eden区满了之后,触发Minor GC,将存活的对象复制到To区,同时清空Eden区和From区。对象经过多次Minor GC仍然存活的,会被移到老年代中。
1.2 优点:
  • 适用于新生代中对象生命周期短的情况,可以高效地回收短命对象。
  • 简单高效,内存分配连续,减少了碎片化。
1.3 缺点:
  • 由于需要复制存活的对象,所以内存开销较大。
  • 需要额外的空间来存放复制后的对象。

2. 老年代(Old Generation)的垃圾回收算法:

老年代主要存放对象生命周期较长的对象,由于对象存活时间较长,采用复制算法将会浪费大量的空间。因此,老年代通常采用其他类型的垃圾回收算法。

2.1 标记-清除算法(Mark-Sweep Algorithm):
  • 首先,标记阶段对所有存活的对象进行标记。然后,在清除阶段,清理掉未标记的对象,即将未标记的对象所占用的内存释放掉。但这种方法可能会产生内存碎片,降低了内存分配的效率。
2.2 标记-整理算法(Mark-Compact Algorithm):
  • 类似于标记-清除算法,但在清除阶段之后,会对存活的对象进行整理,将它们向内存的一端移动,从而消除了内存碎片,提高了内存的利用率。
2.3 优点:
  • 适用于老年代中存活对象较多的情况。
  • 能够避免内存碎片化,提高内存利用率。
2.4 缺点:
  • 清除阶段的效率较低,需要遍历所有对象进行标记。
  • 需要额外的内存空间来存放标记信息。

总的来说,Java的分代垃圾回收算法将堆内存分为新生代和老年代两部分,并针对不同生命周期的对象采用不同的垃圾回收算法,以提高垃圾回收的效率和内存利用率。

IDEA 目录如何平铺

勾选Compact Middle Packages

请添加图片描述

Idea单一个窗口同时打开不同文件夹下的多个maven项目依赖导不进来问题解决

第一步:idea打开多个文件夹的父级文件夹
第二步: 把你想要的项目添加为Maven项目(右键单机pom.xml,将其add as Maven Project即可 )
第三步:重复第二步添加第二个、第三个、第四个、、、、项目
请添加图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值