HotSpot算法细节实现——安全点
OopMap
垃圾回收时,如何找到垃圾?
在可达性分析算法中从GC Roots集合找引用链分析对象是否可达。
固定可作为GC Roots的节点主要在全局性的引用(例如常量或类静态属性)与执行上下文(例如栈帧中的本地变量表),Java应用越做越庞大,光是方法区的大小就常有数百上千兆,里面的类、常量等更是恒河沙数,若要逐个检查以这里为起源的引用肯定得消耗不少时间。
迄今为止,所有收集器在根节点枚举这一步骤时都是必须暂停用户线程,因此根节点枚举也会面临相似的“Stop The World”的困扰。
根节点枚举必须在一个能保障一致性的快照中才得以进行——“一致性”:整个枚举期间执行子系统看起来就像被冻结在某个时间点上,不会出现分析过程中,根节点集合的对象引用关系还在不断变化的情况,是导致垃圾收集过程必须停顿所有用户线程的其中一个重要原因。
实际上虚拟机应当是有办法直接得到哪些地方存放着对象引用的,HotSpot的解决方案中,是使用一组称为OopMap的数据结构来达到这个目的。(一旦类加载动作完成的时候,HotSpot就会把对象内什么偏移量上是什么类型的数据计算出来,在即时编译过程中,也会在特定的位置记录下栈里和寄存器里哪些位置是引用。)
安全点
在OopMap的协助下,HotSpot可以快速准确地完成GC Roots枚举,但没有为每条指令都生成OopMap。
“特定的位置”记录了这些信息,这些位置被称为安全点(Safepoint)。
安全点是以 “是否具有让程序长时间执行的特征”为原则进行选定的,所以方法调用、循环跳转、异常跳转这些位置都可能会设置有安全点。
有了安全点的设定,也就决定了用户程序执行时并非在代码指令流的任意位置都能够停顿下来开始垃圾收集,而是强制要求必须执行到达安全点后才能够暂停。(只有在安全点位置才能进行垃圾收集)
可数循环&不可数循环
HotSpot虚拟机为了避免安全点过多带来过重的负担,对循环还有一项优化措施,认为循环次数较少的话,执行时间应该也不会太长,所以使用int类型或范围更小的数据类型作为索引值的循环默认是不会被放置安全点。这种循环被称为可数循环(CountedLoop)。
使用long或者范围更大的数据类型作为索引值的循环就被称为不可数循环(Uncounted Loop),将会被放置安全点
【可数循环不会被放置到安全点,不可数循环会被放置到安全点】
通常情况下这个优化措施是可行的,但循环执行的时间不单单是由其次数决定,如果循环体单次执行就特别慢,那即使是可数循环也可能会耗费很多的时间。
如果由可数循环耗时时间较长,安全点导致长时间停顿,可以将循环索引的数据类型从int改为long即可。
现象:
当垃圾收集发生时,如果有线程刚好执行到可数循环(较耗时)时,则必须等待循环全部跑完才能进入安全点,此时其他线程也必须一起等着,所以从现象上看就是长时间的停顿。
此时可数循环比较耗时,就可以将循环索引的数据类型从int改为long。
相关文章:
HotSpot算法细节实现——安全点
OopMap 垃圾回收时,如何找到垃圾? 在可达性分析算法中从GC Roots集合找引用链分析对象是否可达。 固定可作为GC Roots的节点主要在全局性的引用(例如常量或类静态属性)与执行上下文(例如栈帧中的本地变量表…...
杂谈:DC对Verilog和SystemVerilog语言的支持
DC对Verilog和SystemVerilog语言的支持 设计语言用哪种?Design Compiler对二者的支持简单的fsm电路测试测试结果对比写在最后 设计语言用哪种? 直接抛出结论:先有电路,后为描述。设计端而言,没有语言的高低好坏&#…...
网络安全评估(网络安全评估)
讨论了基于互联网的网络安全评估和渗透测试的基本原理,网络安全服务人员,安全运营人员,通过评估来识别网络中潜在的风险,并对其进行分类分级。 黑客通常采取的攻击方式如下: 突破目标外围系统,比如主站拿…...
offsetof宏计算某变量相对于首地址的偏移量
宏:offsetof的使用 //offsetof (type,member) //type是结构体的类型名,member是结构体中的成员名。struct Student {char name[5]; // 姓名int age; // 年龄float score; // 成绩 };int main() {struct Student s;printf("%zd\n", off…...
算法|每日一题|统计无向图中无法互相到达点对数|并查集
2316. 统计无向图中无法互相到达点对数 原题地址: 力扣每日一题:统计无向图中无法互相到达点对数 给你一个整数 n ,表示一张 无向图 中有 n 个节点,编号为 0 到 n - 1 。同时给你一个二维整数数组 edges ,其中 edges[i…...
浏览器的四种缓存协议
❤️浏览器缓存 在HTTP里所谓的缓存本质上只是浏览器和业务侧根据不同的报文字段做出不同的缓存动作而已 四种缓存协议如下 Cache-ControlExpiresETag/If-None-MatchLast-Modified/If-Modified-Since 🎡Cache-Control 通过响应头设置Cache-Control和max-age&…...
力扣每日一题55:跳跃游戏
题目描述: 给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false 。 …...
mssql调用外部接口
前言: 断更很久了。 是因为这段时间发现,AI出来之后,很多博客都没有记录的必要了,你问他他都能即时告诉你。 这篇博客产出的原因是,看到一份奇葩需求,说数据库改某行数据的状态字段,也要调用接…...
npx是什么命令?npx和npm有什么区别?
平时安装node模块的时候,经常使用的命令是npm。其实还有另外一个命令,叫做npx。网上的说法都是:npx是npm命令的升级版本,功能非常强大。 npx 是什么 npx是一个由Node.js官方提供的用于快速执行npm包中的可执行文件的工具。它可以…...
1997-2017年各省能源投入数据(万吨标准煤)
1997-2017年各省能源投入数据(万吨标准煤) 1、时间:1997-2017年 2、来源:中国统计年鉴 3、范围:30个省 4、指标:能源投入(各省8种能源消费总量计算得出)(万吨标准煤&…...
C++ Primer笔记001:标准输入输出/基本数据/流程控制语句
文章目录 1.标准输入cin:2.标准输入cout:3.endl:4.命名空间(namespace):5.有符号类型和无符号类型6.字面值常量7.变量的初始化和赋值8.变量的作用域9 求余运算符的符号10.关于sizeof11.switch case语句漏写break 1.标准…...
【C++进阶之路】IO流
文章目录 一、C语言的IO1.键盘与显示屏2. 文件与内存3.字符串与内存 二、CIO1.iostream1.1基本使用1.2operator bool 2. fstream2.1二进制的文件读写2.2字符串的文件读写 3. sstream3.1序列化与反序列化3.2拼接字符串3.3将数据类型转换为字符串 总结 一、C语言的IO 1.键盘与显…...
$GNGGA,传感器传输的数据解析
每一秒传输这一帧数据如下: $GNGGA,090022.000,3959.82136,N,11628.16507,E,1,06,3.5,21.4,M,0.0,M,,*4D $GNGLL,3959.82136,N,11628.16507,E,090022.000,A,A*4F $GPGSA,A,3,03,16,26,,,,,,,,,,4.1,3.5,2.1*32 $BDGSA,A,3,07,21,42,,,,,,,,,,4.1,3.5,2.1*21 $GPGSV…...
javaEE - 2(11000字详解多线程)
一:多线程带来的的风险-线程安全 线程安全的概念:如果多线程环境下代码运行的结果是符合我们预期的,即在单线程环境应该的结果,则说这个程序是线程安全的。 当多个线程同时访问共享资源时,就会产生线程安全的风险&am…...
easyphoto 妙鸭相机
AIGC专栏7——EasyPhoto 人像训练与生成原理详解-CSDN博客如何训练一个高品质的人像Lora与应用高品质Lora的链路对于写真生成而言非常重要。由《LoRA: Low-Rank Adaptation of Large Language Models》 提出的一种基于低秩矩阵的对大参数模型进行少量参数微调训练的方法&#x…...
【Qt控件之QMdiArea】介绍及使用
描述 QMdiArea小部件提供了一个区域,用于显示MDI窗口。QMdiArea的功能类似于MDI窗口的窗口管理器。例如,它在自身上绘制和排列管理的窗口,可以按级联或平铺模式排列它们。通常,QMdiArea被用作QMainWindow的中心小部件,…...
Linux网络编程-极简HTTPUDP服务器
HTTP服务器 #include <stdio.h> #include <string.h> #include <stdlib.h> #include <unistd.h> #include <arpa/inet.h>#define PORT 8080 #define BUFFER_SIZE 2048void handle_client(int client_socket) {char buffer[BUFFER_SIZE];recv(cl…...
虚拟化、容器与Docker基本介绍以及安装部署(Docker 基本管理)
目录 1 Docker 概述 1.1 Docker与虚拟机的区别 1.2 容器在内核中支持2种重要技术 1.3 Docker核心概念 2 安装 Docker 2 Docker 镜像操作 2.1 搜索镜像 2.2 获取镜像 2.3 镜像加速下载 2.4 查看镜像信息 2.4.1 查看下载的镜像文件信息 2.4.2 查看下载到本地的所有镜像…...
Spring Boot中捕获异常错误信息并将其保存到数据库中
Spring Boot中捕获异常错误信息并将其保存到数据库中: 1.创建数据库表: 首先,您需要创建一个用于存储异常信息的数据库表。可以使用SQL脚本或者使用Hibernate实体类来创建表。以下是一个用于存储异常信息的表的示例SQL: CREATE TABLE erro…...
CNN记录】pytorch中flatten函数
pytorch原型 torch.flatten(input, start_dim0, end_dim- 1) 作用:将连续的维度范围展平维张量,一般写再某个nn后用于对输出处理, 参数: start_dim:开始的维度 end_dim:终止的维度,-1为最后…...
别再折腾VS2017了!用VSCode+CMake在Windows上编译GmSSL国密库(附一键脚本)
告别笨重IDE:VSCodeCMake极简编译GmSSL全攻略 在Windows平台编译开源库向来是件令人头疼的事——尤其是当你不得不安装动辄几十GB的Visual Studio全家桶,仅仅是为了使用其中的MSVC编译器。这种"杀鸡用牛刀"的开发体验,让许多追求效…...
BepInEx:解锁Unity游戏无限可能的模组框架
BepInEx:解锁Unity游戏无限可能的模组框架 【免费下载链接】BepInEx Unity / XNA game patcher and plugin framework 项目地址: https://gitcode.com/GitHub_Trending/be/BepInEx 你是否曾经玩过一款Unity游戏,觉得某些功能不够完善,…...
Spring Boot WebFlux 响应式架构原理
Spring Boot WebFlux 响应式架构原理探析 在当今高并发、低延迟的应用场景下,传统的同步阻塞式架构逐渐显露出性能瓶颈。Spring Boot WebFlux 作为响应式编程的典范,通过非阻塞、异步的事件驱动模型,为现代应用提供了更高效的解决方案。本文…...
告别虚拟机!在Win11上用WSL2+Ubuntu22.04搭建RK3568开发环境(保姆级避坑指南)
在Win11上打造高效RK3568开发环境:WSL2Ubuntu22.04全攻略 嵌入式开发工程师们常常面临一个两难选择:要么忍受Windows系统下工具链不完整的痛苦,要么在虚拟机里与卡顿和资源占用作斗争。今天,我要分享的是第三种选择——利用WSL2在…...
嵌入式Linux驱动开发(3)——内核模块机制 - Linux 的插件系统
嵌入式Linux驱动开发(3)——内核模块机制 - Linux 的插件系统 仓库已经开源!所有教程,主线内核移植,跑新版本imx-linux/uboot都在这里!欢迎各位大佬观摩!喜欢的话点个⭐! 仓库地址&a…...
告别点阵:用STM32和TFTLCD(ILI9341)打造一个简易的图形界面菜单
从零构建STM32图形界面:基于ILI9341的嵌入式菜单系统实战 在智能家居控制器、工业仪表等嵌入式设备中,图形用户界面(GUI)已成为提升用户体验的关键要素。传统点阵式LCD已无法满足现代交互需求,而TFT液晶屏配合STM32微控制器,能以较…...
不只是“刷兵”:用《魔兽争霸3》地图编辑器实现一个可扩展的AI敌人系统
不只是“刷兵”:用《魔兽争霸3》地图编辑器实现一个可扩展的AI敌人系统 在《魔兽争霸3》地图编辑的世界里,一个优秀的PVE体验往往取决于敌人AI系统的设计质量。传统"刷兵"机制仅仅解决了"何时生成敌人"的问题,而现代地图…...
开源技术中的开源协议社区运营与贡献管理
开源技术已成为现代软件开发的基石,而开源协议、社区运营与贡献管理则是其可持续发展的核心。开源协议定义了代码的使用、修改与分发规则,社区运营则决定了项目的活跃度与协作效率,贡献管理则直接影响项目的质量与创新速度。这三者相辅相成&a…...
Cogito-v1-preview-llama-3B实战体验:手把手教你启用流式响应,实时对话更流畅
Cogito-v1-preview-llama-3B实战体验:手把手教你启用流式响应,实时对话更流畅 1. 认识Cogito-v1-preview-llama-3B模型 1.1 模型特点概述 Cogito-v1-preview-llama-3B是Deep Cogito推出的混合推理模型,在3B参数规模下展现出超越同类开源模…...
别再死记公式了!用Python+Statsmodels实战拆解AR模型的平稳性、自相关与偏自相关
别再死记公式了!用PythonStatsmodels实战拆解AR模型的平稳性、自相关与偏自相关 时间序列分析中,AR模型就像一位沉默的预言家,通过过去的数据点向我们传递未来的信息。但太多学习者被困在Green函数和Y-W方程的数学迷宫里,忘记了数…...
