秋招突击——8/15——知识补充——垃圾回收机制
文章目录
- 引言
- 正文
- 指针引用
- 可达性分析算法
- 垃圾回收算法
- 标记清除算法
- 标记整理算法
- 复制
- 分代收集
- 垃圾收集器
- Serial收集器
- ParNew并行收集器
- Parallel Scavenge吞吐量优先收集器
- Serial Old老年代收集器
- Parallel old收集器
- CMS收集器
- G1收集器(Garbage First垃圾优先)
- 总结
引言
- 上次面试腾讯,让我说了一下垃圾回收机制,虽然大概都说出来了,但是觉得还是有不够详细,今天好好整理一下,下次不会这么狼狈了!
正文
指针引用
-
Java中对象的访问是需要通过引用进行判断的,引用主要分为其中,按照强度递减分别是:强软弱虚
- 强引用
- 通过new创建的对象,直接用=赋值,如果还存在强引用,垃圾回收器绝对不会回收他
- 软件引用
- 需要使用SoftReference进行声明
- 如果内存不够了,要报异常了,这里就要的优先回收软引用
- 用于对象缓存
Obj obj = new Obj(); SoftReference<Obj> sr = new SoftReference<Obj>(obj)
- 弱引用
- 描述非必须的对象,当一个对象只有弱引用,只要发生GC,一定会被回收
Obj obj = new Obj(); WeakReference<Obj> sr = new WeakReference<Obj>(obj)
- 虚引用
- 最弱的引用,形同虚设
- 仅仅是当前对象被回收了,我能收到通知
- 强引用
可达性分析算法
-
通过一系列GC Root的根对象作为起始节点,然后根据引用关系向下搜索,搜索走过的路径就是引用链。
- GC Root不可达,说明对象不再被使用
- GC Root可达,说明对象仍旧在使用
-
固定为GC Root的对象有以下几种
- 在虚拟栈中引用的对象
- 在方法区,类静态属性引用的对象
- 在方法区,常量引用的对象
- 在本地方法栈中Native方法引用的对象
- Java虚拟机内部的引用
- 同步锁持有的对象
垃圾回收算法
标记清除算法
- 找出所有对象,将存活对象进行标记,然后清理掉未标记的对象,结束。
标记整理算法
- 首先找出所有对象,将存活对象进行标记,然后将存活对象整理一端,将内存区域直接清除掉
复制
- 将内存划分为大小相等的两块,每次只使用其中一块,当这一块内存用完了,就将存活对象复制到另外一块上,然后再将使用过的内存空间进行一次清理
分代收集
- 根据对象的存活周期将内存划分为几块,不同块采用不同的收集算法。
- 一般分为新生代和老年代,
- 新生代
- 绝大多数的对象都是活不过一次垃圾回收
- 使用复制算法
- 老年代
- 大多数是熬过了很多次垃圾回收过程的对象。
- 标记清除 或者 标记整理算法
- 新生代
垃圾收集器
- 目前常用的hotpot虚拟机支持其中垃圾收集器,可以混用。
Serial收集器
- 基本流程
- 暂停所有的工作线程,专门进行垃圾回收
- 针对对象
- 新生代
- 算法
- 复制算法
ParNew并行收集器
- 多线程版的Serial收集器
- 基本流程
- 暂停所有工作线程,使用多线程进行垃圾回收
- 针对对象
- 新生代
- 算法
- 复制算法
Parallel Scavenge吞吐量优先收集器
-
多线程垃圾收集器,尽量压缩垃圾收集时,用户线程的停顿时间
-
基本流程
- 暂停所有工作线程,使用多线程进行垃圾回收
-
针对对象
- 新生代
-
算法
- 复制算法
-
注意
- 需要控制最大垃圾收集停顿时间
- 设置吞吐量大小
Serial Old老年代收集器
- Serial收集器的老年版,使用标记-整理算法,提供客户端模式下使用
- 基本流程
- 暂停所有工作线程,使用多线程进行垃圾回收
- 针对对象
- 老年代
- 算法
- 标记整理算法
Parallel old收集器
-
多线程垃圾收集器,尽量压缩垃圾收集时,用户线程的停顿时间
-
基本流程
- 暂停所有工作线程,使用多线程进行垃圾回收
-
针对对象
- 老年代
-
算法
- 复制算法
-
注意
- 应用于处理器资源较为稀缺的场合,考虑使用Parallel Scavenge 和 Parallel Old一块使用
CMS收集器
-
追求最短停顿时间的垃圾收集器
-
基本流程
- 初始标记
- 停下所有线程,仅仅标记一下GC Root能够关联的对象
- 并发标记
- 用户线程并行,进行GC Roots Tracing,耗时最长
- 重新标记
- 修正并发期间因为程序调用导致的标记变动,停下所有工作线程,耗时较短
- 并发清除
- 用户线程并行,清除掉死亡对象
- 初始标记
-
总结
- 吞吐量低,但是停顿时间少,完成垃圾回收时间长,但是是并行的
- 使用标记清除算法,内存空间不连续,大量的空间碎片
G1收集器(Garbage First垃圾优先)
-
将内存进行分区,然后进行回收价值和成本排序,价值越高成本越低的区块优先回收。
-
特性和问题总结:
- 将整个堆分成大小相同的Region区域,每一个都是Region都可能是新生代、老年代、Eden空间和Survivor空间
- G1每次收集的时候,只会收集部分Region,每次收集时,会先估算每一个小块存活对象的总数,回收垃圾最多的小块会先被收集
- 对于跨Region的引用对象,使用记忆集解决
- 并发标记阶段如何保证收集县城和用户线程互不干扰的运行
- 回收过程中改变对象引用关系:通过原始快照SATB算法实现
- 回收过程中创建新对象:使用单独的分区和指针TAMS保存新创建的对象
-
四个步骤
- 初始标记:
- 仅仅标记一下GC Root能够关联的对象(停顿一下)
- 并发标记:
- 进行可达性分析,完成对象图扫描,判断存活对象和可回收对象
- 处理STAB记录的是否有引用变动的对象
- 最终标记
- 暂时停顿,查看处理并发阶段结束后少量的SATB记录
- 筛选回收
- 根据统计的回收价值和成本并排序,筛选region进行回收
- 使用标记复制的算法实现
- 初始标记:
总结
- 这里是粗浅的理解,后续会在有补充,有很多问题都没有解决,包括怎么进行GC调优呀等等,都没有看!
相关文章:

秋招突击——8/15——知识补充——垃圾回收机制
文章目录 引言正文指针引用可达性分析算法垃圾回收算法标记清除算法标记整理算法复制分代收集 垃圾收集器Serial收集器ParNew并行收集器Parallel Scavenge吞吐量优先收集器Serial Old老年代收集器Parallel old收集器CMS收集器G1收集器(Garbage First垃圾优先&#x…...

【iOS】UITableViewCell的重用问题解决方法
我自己在实验中对cell的重用总结如下: 非自定义Cell和非自定义cell的复用情况一样: 第一次加载创建tableView的时候,是屏幕上最多也显示几行cell就先创建几个cell,此时复用池里什么都没有开始下滑tableView,刚开始滑…...

开发一个微信小程序商城需要哪些技术栈
开发一个小程序商城需要掌握以下技术栈: 前端技术:包括HTML、CSS和JavaScript,用于定义商城的页面结构、样式设计和交互功能。 微信小程序专用技术:如WXML、WXSS、JavaScript和JSON,用于描述小程…...

望繁信科技荣膺上海市浦东新区博士后创新实践基地称号
近日,上海望繁信科技有限公司(简称“望繁信科技”)凭借在大数据流程智能领域的卓越表现,成功入选上海市浦东新区博士后创新实践基地。这一荣誉不仅是对望繁信科技创新能力和技术实力的高度认可,也标志着公司在推动产学…...

Nginx--代理与负载均衡(扩展nginx配置7层协议及4层协议方法、会话保持)
前言:本博客仅作记录学习使用,部分图片出自网络,如有侵犯您的权益,请联系删除 一、代理原理 1、反向代理产生的背景 单个服务器的处理客户端(用户)请求能力有一个极限,当接入请求过多时&#…...

Ubuntu20.4 系统安装后无wifi图标
0. 问题排查 1.检查 BIOS 设置: 有时候,无线网卡可能在 BIOS 中被禁用。重启电脑,进入 BIOS 设置,确保无线网卡选项是启用的。 2.检查硬件开关: 检查您的笔记本电脑是否有物理开关或键盘快捷键来启用或禁用无线网卡。 3.在软件更新中切换…...

牛客网SQL进阶135 :每个6/7级用户活跃情况
每个67级用户活跃情况_牛客题霸_牛客网 0 问题描述 基于用户信息表user_info、、试卷作答记录表exam_record、题目练习记录表practice_record,统计 每个6/7级用户总活跃月份数、2021年活跃天数、2021年试卷作答活跃天数、2021年答题活跃天数,结果 按照总…...

SQLite3使用接口写入二进制文件
使用接口的方式写入二进制文件 ,有二种方案。 一、全部文件 一次性写下到数据中 使用sqlite3_bind_blob接口 FILE* fpfopen("user.bmp","rb"); iLenfread(buffer,1,65535,fp); fclose(fp);sqlite3_prepare(pDB,"insert into user values …...

在复杂的数据库架构中,如何优化 SQL 查询以提高性能和减少资源消耗?
在优化 SQL 查询以提高性能和减少资源消耗时,可以考虑以下几个方面: 使用索引:为经常被查询的列创建索引,可以大大加快查询速度。同时,避免过多的索引,因为过多的索引会增加写入操作的开销。 编写高效的查…...

【HarmonyOS】端云一体化初始化项目
简介 端云一体化开发是HarmonyOS对云端开发的支持、实现端云联动。云开发服务提供了云函数、云数据库、云存储等服务,可以使开发者专注于应用的业务逻辑开发,无需关注基础设施,例如:服务器、操作系统等问题。 因此,…...

LLM之KG:利用大语言模型(LLM)对文本语料提取概念和概念之间的语义关系进而实现自动构建知识图谱
LLM之KG:利用大语言模型(LLM)对文本语料提取概念和概念之间的语义关系进而实现自动构建知识图谱 目录 ML之KG:基于MovieLens电影评分数据集利用基于知识图谱的推荐算法(networkx+基于路径相似度的方法)实现对用户进行Top电影推荐案例 LLMs之AutoKG:《大型语言模型在知识图…...

Spring Security 6如何使用?
Spring Security 6 是一个功能强大且高度可定制的身份验证和访问控制框架,它专注于为基于Java的应用程序提供全面的安全解决方案。以下是对Spring Security 6的详细解析: 一、核心功能 身份验证(Authentication): 验…...

PyTorch深度学习快速入门教程--学习笔记
目录 P4 PyCharm和Jupyter的对比 P5 PyTorch加载数据 P6 Dataset类代码实现 P7 Tensorboard 写日志 读取日志文件 Tensorboard 读图片 P10 Transforms使用 Transforms用途 常见的Transforms工具 P14 torchvision数据集使用 P15 Dataloader使用 P16 nn.Module模块使…...

SQLALchemy 分组过滤、子查询
SQLALchemy 分组过滤、子查询 分组和过滤(Group By Having)示例:使用ORM示例:使用SQLAlchemy Core子查询(Subquery)SQLAlchemy 是一个流行的 SQL 工具包和对象关系映射(ORM)库,用于 Python 应用程序。它允许你以 Pythonic 的方式使用 SQL 数据库,同时提供了强大的查询…...

华为od(D卷) 环中最长子串/字符成环找偶数LOX
文章目录 题目描述输入描述输出描述示例1示例2示例3思路代码 题目描述 给你一个字符串 s,字符串 s 首尾相连成一个环形,请你在环中找出 ‘l’、‘o’、‘x’ 字符都恰好出现了偶数次最长子字符串的长度。 输入描述 输入是一串小写的字母组成的字符串 …...

机器学习--常见算法总结
有监督学习算法 1. 线性回归算法 概念:线性回归是一种统计方法,用于预测一个变量(因变量)与一个或多个自变量(特征变量)之间的关系。目标是通过线性方程建立自变量和因变量之间的关系模型。 作用&#x…...

QT 网络聊天室简易版
视频:qt开发网络聊天w室软件3.4界面开发_哔哩哔哩_bilibili 目录 UI部分 设计稿图 放置控件 界面美化 拖动窗体 设置界面 网络部分 配置对话框 多项目结果和服务器端设计 客户端框架开发 UI部分 设计稿图 放置控件 界面美化 现在我们把窗体自带的标题栏给去了,用我们自…...

Linux_Shell三剑客grep,awk,sed-08
三剑客的概述: awk、grep、sed是linux操作文本的三大利器,合称文本三剑客,也是必须掌握的linux命令之一。三者的功能都是处理文本,但侧重点各不相同,其中属awk功能最强大,但也最复杂。grep更适合单纯的查找…...

uniapp实现足球数据分析平台移动端H5
文章目录 前言一直想做一款足球分析平台,大概内容包括竞彩分析模块,即时预测模块,初盘分析模块,找来找去还是前端铺子的样式感觉比较好看。 一、界面一栏二、注册界面1.代码说明 三、首页界面四、竞彩预测五、即时预测总结 前言 …...

Redis5优化-Redis
1、Redis关键参数 a、客户端最大连接数 maxclients 60000 注意该参数受到操作系统最大文件句柄的限制(ulimit -n) b、响应 repl-ping-slave-period/repl-timeout repl-timeout 60 1)、说明:slave 会每隔 repl-ping-slave-period(默认10秒)ping一次mast…...

Element UI【详解】el-scrollbar 滚动条组件
el-scrollbar 滚动条组件用于优化页内滚动条的UI效果,使用时必须指定高度! /*el-scrollbar 必须指定高度*/ .scrollMenuBox {height: 200px;width: 100px;border: 1px solid red; } 控制el-scrollbar内滚动条的方法与控制页面的滚动条的方法基本一样&a…...

【精选】基于Python大型购物商城系统(京东购物商城,淘宝购物商城,拼多多购物商城爬虫系统)
目录: 目录: 系统介绍: 系统开发技术 Python语言 Django框架简介 MySQL数据库技术 B/S架构 系统设计 系统总体设计 系统详细界面实现: 系统测试 测试目的 测试用例 本章小结 参考代码: 为什么选择我&…...

QT翻金币小游戏(含音频图片文件资源)
目录 QT翻金币小游戏 音频图片资源文件获取 效果展示 图片 视频 实现代码 main.cpp mymainwindow.h mymainwindow.cpp startscene.h startscene.cpp selectscene.cpp playscene.h playscene.cpp mypushbutton.h mypushbutton.cpp dataconfig.h dataconfig.cpp QT…...

Linux配置JDK8环境变量
目录 一、yum安装1.1 OpenJDK安装1.2 测试是否能够使用1.3 如何卸载JDK 二、手动安装2.1 下载2.2 上传到linux服务器路径2.3 解压2.4 配置环境变量2.5 测试是否能够使用 一、yum安装 1.1 OpenJDK安装 sudo yum install -y java-1.8.0-openjdk-devel1.2 测试是否能够使用 jav…...

Fiddle抓手机app的包
前言 本次文章讲述的是,fiddle获取手机代理,从而获取手机app的http、https请求! 一.下载安装汉化Fiddle 1.点击Fiddler官网下载链接:Download Fiddler Web Debugging Tool for Free by Telerik 2.直接运行,选择自己需…...

Oracle+ASM+High冗余详解及空间计算
Oracle ASM(Automatic Storage Management)的High冗余模式是一种提供高度数据保护的策略,它通过创建多个数据副本来确保数据的可用性和安全性。 以下是关于Oracle ASM High冗余的详细解释: 一、High冗余的特点 1.数据冗余度 在Hi…...

如何为 Nextcloud 配置自动数据库备份 - 应用程序
自动数据库备份模块简化了生成数据库计划备份的过程。这些备份可以存储在各种位置,包括本地驱动器、FTP 服务器、SFTP 服务器、Dropbox、Google Drive、OneDrive、NextCloud 和 Amazon S3 云存储。用户还可以选择启用自动删除过期备份的功能。此外,用户可…...

child_process.spawn简介
child_process.spawn 是 Node.js 中 child_process 模块的一个重要方法,它用于异步地创建子进程来执行指定的命令。下面是对 child_process.spawn 的深入解析: 一、基本用法 spawn 方法的基本语法如下: const { spawn } require(child_pr…...

整理给测试人看的千页面试题
人往高处走水往低处流,九月已来,“金九银十”招聘季还会远吗? 转眼2024年招聘季就要来了,没点真本事真技术,没点面试经验,不了解点职场套路,如何过五关斩六将?如何打败面试官&#…...

Linux 内核中的并发与竞争
1. 引入并发与竞争的概念 在现代计算环境中,多个任务和线程通常会同时执行,因此理解并发和竞争的特性与挑战至关重要。以下是对这两个概念的详细介绍。 1. 并发(Concurrency) 定义: 并发是指多个任务在同一时间段内…...