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

【学习笔记】深入理解Java虚拟机学习笔记——第11章 后端编译与优化

第11章 后端编译与优化

11.1 概述

11.2 即时编译器

11.2.1 解释器与编译器

C1客户端编译器:优化力度小,编译快
C2服务端编译器:优化力度大,编译慢
解释器会在解释执行时收集运行数据供编译使用,以上各行为是否存在与占比情况由运行参数与版本决定

11.2.2 编译对象与触发条件

热点代码:多次调用的方法,多次执行的循环体(也会编译方法体,栈上替换)
热点代码探测方式:
1>基于采样的热点探测:周期检查各线程调用栈,经常出现在栈顶则为热点代码
优点:易于获得调用栈信息
缺点:易受阻塞扰乱热点探测
2>基于计数器的热点探测:为每个方法建立调用计数器
优点:统计调用次数准确
缺点:不能获取调用关系
Hotspot虚拟机使用第二种计数器,方法调用与循环都有各自的计数器(默认C1 1500次,C2 10000次)【可配置】
【一个方法调用时,先查看是否有编译后的版本,有则执行。无则计数器+1,达到阈值后提交一个该方法编译请求,然后继续调用解释器执行方法,编译成功后会通过编译后的代码执行。若方法一段时间内还未达热点,会减少一般调用次数统计】
回边计数:阈值计算(C1默认 13995,C2默认10700)
若存在已编译版本则执行,否则计数器+1且判断是否达到阈值,打到发送编译请求,并将回边计数减小,继续执行。
回边计数溢出时,会把方法调用计数一并溢出。

11.2.3 编译过程

客户端:三段式,重点关注局部优化而放弃全局优化
服务端:优化强度堪比c++ -02参数(无用代码消除、循环展开等…)

相关文章:

  • leetcode练习
  • Hologres的EXPLAIN和EXPLAIN ANALYZE简介
  • 如何用AI开发完整的小程序<10>—总结
  • 【笔记】Windows 系统迁移 Ubuntu(Preview)应用到其他磁盘
  • STM32HAL库 -- 8.串口UART通信并开启printf功能
  • 一次使用 RAFT 和 Qwen3 实现端到端领域RAG自适应
  • Nginx 基础知识
  • AWS认证系列:考点解析 - cloud trail,cloud watch,aws config
  • RA4M2开发IOT(6)----涂鸦模组快速上云
  • 肖臻《区块链技术与应用》第六讲:比特币网络
  • EXPLAIN优化 SQL示例
  • moduo之Socket类以及Sockets命名空间
  • [project-based-learning] docs | 教程列表 | 格式规范 | 锚点分类体系
  • VTK链接程序问题记录
  • 元素-标签-复制
  • [Linux] Vim编辑器 Linux输入输出重定向
  • Nginx-5 Nginx 的4层反向代理
  • 【node】Mac m1 安装nvm 和node
  • 64-Oracle Redo Log
  • 示波器测量市电需要隔离变压器
  • 怎么让网站绑定域名访问/互联网舆情监测系统
  • 网站如何进行seo/百度网站排名优化价格
  • 重庆城乡建设委员会的网站/软文写作公司
  • 丰功网站建设/关键词推广排名软件
  • 网站建设实训内容/常用的网络推广手段有哪些
  • vvic网站一起做网店/网络推广及销售