1.OpenJDK17-JVM 源码阅读 - ZGC - 并发标记 | 京东物流技术团队
2.window.openç示ä¾
3.Spring Cloud OpenFeign源码FeignClientFactoryBean原理
4.openctp通道源码开放二(新浪行情CTPAPI)
5.opensips2.4源码分析udp协议处理
6.Linux环境编程——打开文件、源码open 介绍、推荐open 源码、源码文件描述符 fd 与文件管理结构 file
OpenJDK17-JVM 源码阅读 - ZGC - 并发标记 | 京东物流技术团队
ZGC简介:
ZGC是推荐Java垃圾回收器的前沿技术,支持低延迟、源码大容量堆、推荐易语言源码加法染色指针、源码读屏障等特性,推荐自JDK起作为试验特性,源码JDK起支持Windows,推荐JDK正式投入生产使用。源码在JDK中已实现分代收集,推荐预计不久将发布,源码性能将更优秀。推荐
ZGC特征:
1. 低延迟
2. 大容量堆
3. 染色指针
4. 读屏障
并发标记过程:
ZGC并发标记主要分为三个阶段:初始标记、源码并发标记/重映射、重分配。本篇主要分析并发标记/重映射部分源代码。
入口与并发标记:
整个ZGC源码入口是ZDriver::gc函数,其中concurrent()是一个宏定义。并发标记函数是jar 避免源码泄露concurrent_mark。
并发标记流程:
从ZHeap::heap()进入mark函数,使用任务框架执行任务逻辑在ZMarkTask里,具体执行函数是work。工作逻辑循环从标记条带中取出数据,直到取完或时间到。此循环即为ZGC三色标记主循环。之后进入drain函数,从栈中取出指针进行标记,直到栈排空。标记过程包括从栈取数据,体感控制源码标记和递归标记。
标记与迭代:
标记过程涉及对象迭代遍历。标记流程中,ZGC通过map存储对象地址的finalizable和inc_live信息。map大小约为堆中对象对齐大小的二分之一。接着通过oop_iterate函数对对象中的指针进行迭代,使用ZMarkBarrierOopClosure作为读屏障,实现了指针自愈和防止漏标。
读屏障细节:
ZMarkBarrierOopClosure函数在标记非静态成员变量的指针时触发读屏障。慢路径处理和指针自愈是校园留言墙源码核心逻辑,慢路径标记指针,快速路径通过cas操作修复坏指针,并重新标记。
重映射过程:
读屏障触发标记后,对象被推入栈中,下次标记循环时取出。ZGC并发标记流程至此结束。
问题回顾:
本文解答了ZGC如何标记指针、三色标记过程、如何防止漏标、ts 同步源码计算指针自愈和并发重映射过程的问题。
扩展思考:
ZGC在指针上标记,当回收某个region时,如何得知对象是否存活?答案需要结合标记阶段和重分配阶段的代码。
结束语:
本文深入分析了ZGC并发标记的源码细节,对您有启发或帮助的话,请多多点赞支持。作者:京东物流 刘家存,来源:京东云开发者社区 自猿其说 Tech。转载请注明来源。
window.openç示ä¾
1ãæåºæ¬çå¼¹åºçªå£ä»£ç å ¶å®ä»£ç é常ç®åï¼
<SCRIPT LANGUAGE=javascript>
<!--
window.open ('page.html')
-->
</SCRIPT>
å 为è¿æ¯ä¸æ®µjavascripts代ç ï¼æ以å®ä»¬åºè¯¥æ¾å¨<SCRIPT LANGUAGE=javascript>ï¼æ ç¾å</script>ï¼ä¹é´ã<!-- å -->ï¼æ¯å¯¹ä¸äºçæ¬ä½çæµè§å¨èµ·ä½ç¨ï¼å¨è¿äºèæµè§å¨ä¸ä¸ä¼å°æ ç¾ä¸ç代ç ä½ä¸ºææ¬æ¾ç¤ºåºæ¥ãè¦å »æè¿ä¸ªå¥½ä¹ æ¯åã
Window.open ('page.html') ç¨äºæ§å¶å¼¹åºæ°ççªå£page.htmlï¼å¦æpage.htmlä¸ä¸ä¸»çªå£å¨åä¸è·¯å¾ä¸ï¼åé¢åºåæè·¯å¾ï¼ç»å¯¹è·¯å¾ï¼/list=sz...
多个股票: hq.sinajs.cn/list=sh...
然而,去年新浪对协议进行了调整,改动了HTTP头部,需额外添加特定字段,否则访问会被拒绝。详情请参考相关文章:《新浪行情无法接收的解决方法》。
CTPAPI在期货领域广为人知,但在股票市场中可能较少被提及。为了帮助用户更好地理解如何利用此接口接收股票行情,本文提供了一个示例。同时,公开了新浪行情CTPAPI源码地址,用户可访问:tl.h 中,open 函数的声明确认了这一事实:extern int open(const char *file, int oflag, ...) nonnull ((1))。这说明 open 函数接收变长参数。
open 函数的参数包括要打开的文件路径、打开方式标志和可变参数。除了常用的几个选项,APUE 还介绍了 POSIX 定义的常用选项。然而,并非所有文件系统都支持所有选项。
通过分析内核源码,可以深入了解打开文件的过程。内核在 open->do_sys_open 这一部分执行了文件描述符和内核管理文件结构的分配。这说明打开文件时,内核主要消耗了这两种资源。
在 Linux 中,获取新文件描述符时,遵循 POSIX 标准,返回最低的未使用文件描述符。这通过 do_sys_open->get_unused_fd_flags->alloc_fd(0, (flags)) 实现,该函数选择合适的文件描述符。
内核使用 fd_install 将文件管理结构 file 与 fd 组合起来,当用户使用 fd 与内核交互时,内核通过 fd 从 fdt->fd[fd] 中得到管理文件的内部结构 struct file。
2024-11-26 23:39
2024-11-26 23:15
2024-11-26 23:11
2024-11-26 22:55
2024-11-26 22:36
2024-11-26 21:28