JVM系列(十):JVM垃圾回收算法相关知识

       

         

今天给大家继续分享JVM垃圾回收算法相关知识,如有不对的地方欢迎指正。

JVM垃圾回收算法主要有标记清除、复制算法、标记整理、分代收集四种,下面来逐一介绍。

1、标记清除(Mark-Sweep)

       

        

标记清除作为最基础的垃圾回收算法,其过程要经历两个阶段:标记、回收。

标记:遍历内存区域,标记出待回收的对象。

回收:再次遍历内存区域,然后对已标记的对象占用的内存进行回收。

缺点:

  • 需要遍历两次内存区域,效率低。

  • 因为JVM存储特点是逻辑上连续,物理上可以不连续,标记清除算法可能产生大量内存碎片,当JVM需要一块比较大的内存空间的时候,而又找不到合适的内存空间,就会触发下一次的垃圾回收操作。

2、复制算法(Copy)

              

 

复制算法主要是解决标记—清除算法遍历的和产生内存碎片的缺点,在其基础上进行改进而来的,它会将可用内存按容量分为大小相等的两块,每次只能使用其中的一块,当正在使用的这一块的内存空间不满足使用的时候,就会将还存活的对象复制到另外一块空的内存上面,然后再把当前内存空间一次清理掉。

复制算法在新生代中两个幸存区(From 、To)的不停交换是最典型的用法,

新生代内存空间占比为 8(Eden 伊甸园区  ):1 (To Survivor):1 (Survivor From)。

优点

  • 内存回收时,不会产生内存碎片

  • 回收的时候只需移动栈顶指针,按顺序分配内存即可,实现简单

  • 每次只对两块中的一块内存进行回收,效率高

  • 复制算法执行后,空间时连续的。

缺点

一次性分配内存只能用其中的一半,内存的最大可利用率只有一半。

3、标记整理(Mark-Compact)

               

 

标记整理算法主要是针对老年代来设计的。

执行过程

  • 标记:对需要回收对象的进行标记

  • 整理:让存活的对象,向内存的一端移动,在整理的过程中,之前对象的在虚拟机栈中的引用地址也随之发生改变,最后直接清理掉非存活对象的内存空间。

优点

  • 没有碎片化内存产生(标记清除算法比较)

  • 没有了内存利用率减半的消耗(复制算法比较)

缺点

  • 效率相比标记复制算法稍低

  • 在整理存活对象过程中,因为存活对象位置点变动,需要调整对象在虚拟机栈中的引用地址,同时需要全程暂停用户线程,STW(Stop The World)

4、分代收集算法

严格意义上来说分代收集不能算一种新的垃圾回收算法,分代收集其实只是根据对象的存活的时间的长短,将新生代和老年代针对不同的内存区域,采取对应的算法。目前市面上大多商用虚拟机都采用分代收集算法,

新生代:每次都有大量对象消亡,因为有老年代作为内存担保,比较采取复制算法。

老年代:对象存活时间长,可采用标记整理、标记清除算法。

5、三种垃圾回收算法对比

对比参数

标记清除

标记整理

标记复制

速度

中等

最慢

最快

空间开销

少(会产生碎片)

少(不会产生碎片)

2倍开销

移动对象

适合场景

老年代

老年代

新生代

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/270019.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java8 拼接字符串 StringJoiner

StringJoiner是Java8新出的一个类,用于构造由分隔符分隔的字符序列,并可选择性地从提供的前缀开始和以提供的后缀结尾。省的我们开发人员再次通过StringBuffer或者StingBuilder拼接。 我们查看一下一下代码,试着猜一下。 1.简单的字符串拼接…

分享Git常见的项目托管平台

今天给大家分享Git常见的项目托管平台,大家一起来看看吧! 1、GitHub GitHub是一个面向开源及私有软件项目的托管平台,因为只支持Git作为唯一的版本库格式进行托管,故名GitHub。是全球最大、代码质量最高的Git开源项目平台。遗憾的…

网络技巧:教你给路由器装上电池,断电照样可以上网

家里要是停电了,你的WiFi还能上网吗?想都不用想,“肯定不能”估计所有人都会这样回答。如果小编跟你说即使停电了,也有个小方法让你能够用WiFi,你会相信不?下面大家一起来看看吧! 其实&#xff…

电脑软件:推荐一款磁盘空间分析工具——WizTree

目录 1、WizTree是啥? 2、WizTree的特点 2.1 磁盘空间利用率分析 2.2 扫描速度快 2.3 支持多文件系统格式 2.4 树状图显示 2.5 大文件快速查找 2.5 支持文件名模糊搜索 2.6 支持导出文件和 MFT 数据 2.7 支持导入文件和 MFT 数据 2.8 命令行支持 3、总结…

分布式自增ID算法---雪花算法(SnowFlake)Java实现

分布式id生成算法的有很多种,Twitter的SnowFlake就是其中经典的一种。 算法原理 SnowFlake算法生成id的结果是一个64bit大小的整数,它的结构如下图: 1bit,不用,因为二进制中最高位是符号位,1表示负数&…

软件:给大家推荐一款国产非常好用的效率软件uTools

目录 1、uTools介绍 2、安装下载 3、uTools常用功能介绍 今天给大家推荐一款办公人员必备的效率软件uTools,可以大幅度提升你的生产力,感兴趣的朋友可以下载试一试,相信你一定会爱不释手。 1、uTools介绍 uTools是一款插件化,极简、跨平…

数据库知识:SQLServer创建非sa用户笔记

数据库安全是数据库运维非常重要的环节,今天给大家分享SQLServer如何创建非sa用户,并且设置数据库对应的访问权限,希望对大家能有所帮助! 1、创建登录名 1.1、创建登录名 安全性→登录名→新建登录名(鼠标右键&#xf…

微软电脑管家2.0公测版体验

前言 微软电脑管家2.0公测版本终于发布了,之前给大家分享过微软电脑管家测试版的文章,今天给大家再介绍一下微软电脑管家2.0公测版究竟带来了哪些更新,大家一起来看看吧! 安装要求 微软官方公布的安装要求是windows10的1809版本…

布隆过滤器(Bloom Filter)的原理和实现

布隆过滤器使用场景 之前在《数学之美》里面看到过布隆过滤器的介绍。那么什么场景下面需要使用布隆过滤器呢? 看下下面几个问题 字处理软件中,需要检查一个英语单词是否拼写正确在 FBI,一个嫌疑人的名字是否已经在嫌疑名单上在网络爬虫里&a…

硬件知识:RTMP和RTSP传统流媒体协议介绍

今天给大家分享RTMP和RTSP传统流媒体协议介绍,希望对大家能有所帮助! 1、RTSP 1.1 RTSP协议介绍 RTSP (Real-Time Stream Protocol)由Real Networks 和 Netscape共同提出的,基于文本的多媒体播放控制协议。RTSP定义…

电脑知识:台式电脑应该选择品牌和组装,值得收藏

互联网时代的发展,电脑对大家日常办公、游戏、影音娱乐都是常用的设备。今天主要给大家分享一下购买台式电脑应该注重品牌还是组装,相信看完本文对你选购台式电脑提供更多的参考。 1、品牌电脑 品牌电脑就是由大品牌电脑厂商(联想、IBM、戴…

Docker基础:Docker是什么,为什么这么火

一、Docker是什么? Docker是一个开源的应用容器引擎,它基于go语言开发,并遵从Apache2.0开源协议。使用Docker可以让开发者封装他们的应用以及依赖包到一个可移植的容器中,然后发布到任意的 Linux 机器上运行。Docker 的核心思想打…

信息系统 项目十大管理和五大过程

PMBOK五大过程组是什么? PMBOK五大过程组是:启动过程、规划过程、执行过程、监控过程、收尾过程。 各用一句话概括项目管理知识体系五大过程组: 1、启动过程组:作用是设定项目目标,让项目团队有事可做; 2、…

Docker基础:Docker安装及镜像加速配置

今天给大家分享Centos7以上版本的操作系统下安装Docker。 目录 卸载旧版本docker 安装docker需要的安装包 设置镜像仓库 国内常见镜像仓库 安装docker 启动docker 运行hello-world 卸载docker(谨慎操作) 确认操作系统版本 #查看系统内核 uname …

高并发场景下,到底先更新缓存还是先更新数据库?

在大型系统中,为了减少数据库压力通常会引入缓存机制,一旦引入缓存又很容易造成缓存和数据库数据不一致,导致用户看到的是旧数据。 为了减少数据不一致的情况,更新缓存和数据库的机制显得尤为重要,接下来带领大家踩踩…

Xamarin组件包 Xamarin.ToolKit

一 简介 Xamarin.ToolKit是个人在使用xamrin.froms开发2年中,因实际项目需要所自定义的组件包。该组件包采用xamarin.froms方式封装,用户可像普通forms控件那样使用xaml语言编写UI代码。目前该组件包的成员主要: 1 TabbedPage.cs&#xff1a…

每个工程师都应该了解的:聊聊幂等

现在这个时代大家可能最关心的就是钱了,那么有没有想过你银行转账给你没有一次是转多的,要么失败,要么成功,为什么不能失误一下多转一笔呢?醒醒吧年轻人,别做梦了,做银行的能那么傻x吗&#xff…