当前位置: 首页 > news >正文

来宾建设网站巨量算数

来宾建设网站,巨量算数,做性事的视频网站,wordpress网站导航垃圾收集 分代理论Java 堆的内存分区不同分代收集垃圾收集算法 分代理论 弱分代假说:绝大多数对象都是朝生夕灭,即绝大多数对象都是用完很快需要销毁的。强分代假说:熬过多次垃圾收集过程的对象就越难以消亡,即如果对象经过多次垃…

垃圾收集

        • 分代理论
        • Java 堆的内存分区
        • 不同分代收集
        • 垃圾收集算法

分代理论

  • 弱分代假说:绝大多数对象都是朝生夕灭,即绝大多数对象都是用完很快需要销毁的。
  • 强分代假说:熬过多次垃圾收集过程的对象就越难以消亡,即如果对象经过多次垃圾收集后仍存活,那么这些对象一般是长久存在难以消亡的,即进入永久代。
  • 跨代引用假说:跨代引用相对同代引用占极少数,即对象间的引用一般是在同代之间的,即弱引用之间存在引用、强引用之间存在引用,但他们一般很少存在相互引用。

Java 堆的内存分区

按照垃圾收集,将 Java 堆划分为**新生代 (Young Generation)老年代(Old Generation)**两个区域,新生代存放存活时间短的对象,而每次回收后存活的少量对象,将会逐步晋升到老年代中存放。

而新生代又可以分为三个区域,eden、from、to,比例是 8:1:1,而新生代的内存分区同样是从垃圾收集的角度来分配的。

在这里插入图片描述

不同分代收集

部分收集(Partial GC):指目标不是完整收集整个 Java 堆的垃圾收集,其中又分为:

  • 新生代收集(Minor GC/Young GC):指目标只是新生代的垃圾收集。
  • 老年代收集(Major GC/Old GC):指目标只是老年代的垃圾收集。目前只有CMS 收集器会有单独收集老年代的行为。
  • 混合收集(Mixed GC):指目标是收集整个新生代以及部分老年代的垃圾收集。目前只有 G1 收集器会有这种行为。

整堆收集(Full GC):收集整个 Java 堆和方法区的垃圾收集。

垃圾收集算法

  1. 标记-清除算法

见名知义,标记-清除(Mark-Sweep)算法分为两个阶段:

  • 标记 : 标记出所有需要回收的对象
  • 清除:回收所有被标记的对象
    在这里插入图片描述

标记-清除算法比较基础,但是主要存在两个缺点:

  • 执行效率不稳定,如果 Java 堆中包含大量对象,而且其中大部分是需要被回收的,这时必须进行大量标记和清除的动作,导致标记和清除两个过程的执行效率都随对象数量增长而降低。
  • 内存空间的碎片化问题,标记、清除之后会产生大量不连续的内存碎片,空间碎片太多可能会导致当以后在程序运行过程中需要分配较大对象时无法找到足够的连续内存而不得不提前触发另一次垃圾收集动作。
  1. 标记-复制算法

标记-复制算法解决了标记-清除算法面对大量可回收对象时执行效率低的问题。

过程也比较简单:将可用内存按容量划分为大小相等的两块,每次只使用其中的一块。当这一块的内存用完了,就将还存活着的对象复制到另外一块上面,然后再把已使用过的内存空间一次清理掉。

在这里插入图片描述

这种算法存在一个明显的缺点:一部分空间没有使用,存在空间的浪费。

新生代垃圾收集主要采用这种算法,因为新生代的存活对象比较少,每次复制的只是少量的存活对象。当然,实际新生代的收集不是按照这个比例。

Appel式回收的具体做法是把新生代分为一块较大的Eden空间两块较小的Survivor空间,每次分配内存只使用Eden和其中一块Survivor。发生垃圾搜集时,将Eden和Survivor中仍然存活的对象一次性复制到另外一块Survivor空间上,然后直接清理掉Eden和已用过的那块Survivor空间。HotSpot虚拟机默认Eden和Survivor的大小比例是8∶1,也即每次新生代中可用内存空间为整个新生代容量的90%(Eden的80%加上一个Survivor的10%),只有一个Survivor空间,即10%的新生代是会被“浪费”的。

此Appel式回收还有一个充当罕见情况的“逃生门”的安全设计,当Survivor空间不足以容纳一次Minor GC之后存活的对象时,就需要依赖其他内存区域(实际上大多就是老年代)进行分配担保(Handle Promotion)。如果另外一块Survivor空间没有足够空间存放上一次新生代收集下来的存活对象,这些对象便将通过分配担保机制直接进入老年代,这对虚拟机来说就是安全的。

  1. 标记-整理算法

为了降低内存的消耗,引入一种针对性的算法:标记-整理(Mark-Compact)算法。

其中的标记过程仍然与“标记-清除”算法一样,但后续步骤不是直接对可回收对象进行清理,而是让所有存活的对象都向内存空间一端移动,然后直接清理掉边界以外的内存。

在这里插入图片描述

标记-整理算法主要用于老年代,移动存活对象是个极为负重的操作,而且这种操作需要 Stop The World 才能进行,只是从整体的吞吐量来考量,老年代使用标记-整理算法更加合适。

http://www.tj-hxxt.cn/news/5400.html

相关文章:

  • 网站制作合肥北京百度公司地址在哪里
  • html5网站开发案例网络营销心得体会1000字
  • 网站建设布局设计seo优化方法
  • 杭州做网站套餐可以打广告的平台
  • 公司网站域名做邮箱网络营销渠道有哪三类
  • 大良招聘网站建设品牌推广软文
  • 做网站需要的硬件seo推广的特点
  • 旅游网站建设方案两百字kol推广
  • 便宜做网站靠谱吗网络营销知识点
  • 辽宁网站建设企业中国第三波疫情将在9月份
  • 江门做网站价格搜索引擎营销原理
  • 免费国外云服务器黄山seo
  • 天津企业网站建设沈阳seo团队
  • 找兼职做网站的哪里找微信投放广告多少钱
  • 长沙做网站费用电脑版百度网盘
  • 微博推广文案怎么写优化seo系统
  • wordpress 子域名天桥区seo全网宣传
  • 如何做网站竞价排名楚雄百度推广电话
  • wordpress设置备案白银网站seo
  • 1688网站如何运营链友之家
  • 新乡网站优化公司价格做网站一般需要多少钱
  • 网站标题导航栏网络营销概念
  • 口碑好的秦皇岛网站建设价格网站建设优化
  • 长沙网站优化诊断seo平台优化服务
  • 网站备案花钱么今日国内新闻摘抄十条
  • 网站推广是做什么的小红书seo是什么意思
  • discuz网站搬家教程好消息疫情要结束了
  • 莱芜网站推广如何用百度平台营销
  • 河南两学一做网站百度搜索指数1000是什么
  • wordpress图片分组点击精灵seo