深入理解JVM阅读笔记

1. JVM运行时数据区

除了方法区和堆属于线程共享,其它属于线程私有。

1.1. 程序计数器

Java文件经过javac编译成字节码文件后,通过字节码解释器执行字节码指令时,存在线程上下文切换。程序计数器用于记录字节指令的行号,这样线程上下文切换之后,字节码解释器才会记得上一个线程执行到哪个位置。

1.2. 虚拟机栈

  • Java方法
  • 递归调用方法存在StackoverflowError
  • 操作数栈,动态链接
  • 疑问:频繁出栈和入栈是否会影响应用性能?

1.3. 本地方法栈

非Java方法

举例:CAS是一条CPU原子指令,类似数据库乐观锁的作用,JUC。

1.4. 方法区

存储类信息,常量(常量池,hashSet实现不允许重复),静态变量等。

存在OM

1.5. 堆

1)负责数组和实例对象创建和存储(分配内存)。

2)存在OM

3)堆结构:

  • 新生代
    • Eden 8
    • Survivor 2
      • Survivor From 1
      • Survivor To 1
  • 老年代

4)-Xmx -Xms

5)HotSpot 使用永久代实现方法区,目的是想让GC管理这块内存。

6)即便JVM提供自动分配和释放内存,程序依然存在内存泄漏内存溢出的问题。

2. 对象创建流程

2.1. 检查

  • 若常量池中存在类符号引用,则类已加载,直接分配内存

2.2. 加载

2.3. 分配内存

  • 指针碰撞
  • 空闲列表 CAS

2.4. 初始化

2.5. 执行<init>

  • static代码块

3. Java对象内存布局

3.1. 对象头

3.2. 实例数据

3.3. 对齐填充

4. 如何访问对象

4.1. 直接指针访问

  • 访问效率高,不方便GC回收

4.2. 对象句柄访问

  • 方便GC回收,访问效率低

5. GC回收如何对象?

  1. 配置虚拟机启动参数。配置参数之后,程序运行期间,若发生GC,就会打印GC日志详情。
vm options: -verbose:gc -XX+PrintGcDetails
  1. 在程序中通过调用静态方法,触发GC
System.gc();

5.1. 引用计数法

  • 优点是简单方便,缺点是无法检测循环引用。

5.2. 可达性分析法

  • GCRoute,引用链
  • HotSpot 采用这种方式。

6. 垃圾回收算法

6.1. 标记清除算法

  • 被标记的垃圾:不存在引用链
  • 存在问题:1)清除之后的内存是不连续的。2)标记和清除效率低。

6.2. 复制算法

  • 两大内存区域(Eden、Survivor),搬运
  • 主要负责回收新生代对象。这是因为新生代区域内大部分对象是会被回收的,只有少部分对象需要被保留,被保留到Survivor中。
  • Survivor To 用来保存 Eden 和 Survivor From 存活的对象,然后再转移到 Survivor From ,等待第二次回收。
  • 若Survivor To 空间不足时,采取分配担保,将对象转移到老年代。

6.3. 标记-整理算法

  • 覆盖,然后清除垃圾???
  • 适用于老年代

6.4. 分代收集算法

  • 新生代使用复制算法,老年代使用标记-整理算法或标记清除算法

7. 垃圾回收器

7.1. Serial

  • 用户线程,GC线程
  • stop the work
  • 单线程,垃圾回收时,必须暂停其它工作线程,直到垃圾回收结束。
  • 客户端
  • 适用于桌面端应用。因为桌面端应用内存小,回收时间比较短,只要不太频繁就可以接受。

7.2. ParNew

  • Serial 多线程版本
  • stop the work
  • 服务器端
  • 使用-XX:ParallelGCThreads参数限制垃圾收集的线程数,对应CPU核数。线程数太多导致频繁的上下文切换,浪费资源。
  • 并行和并发
  • 适用于新生代
  • 多线程操作存在上下文切换问题。若电脑是单核CPU,那么使用Serial效率更高,若电脑是多核CPU,那么建议使用 ParNew并行处理,要注意限制垃圾收集的线程数,尽量避免不必要的上下文切换。

7.3. Parallel Scavenge

  • 新生代收集器 复制算法
  • stop the work
  • 并行多线程垃圾回收器(与ParNew一样)
  • 吞吐量优先
  • 设置GC停顿时间,较小会发生频繁GC
  • 设置吞吐量 99%,用户线程占99%,合适时性能最优

7.4. Serial old

  • 单线程
  • 老年代
  • 标记-整理算法
  • Serial 使用复制算法,Serial old 使用标记-整理算法

7.5. Parallel old

  • 多线程,并行
  • 老年代
  • 标记-整理算法
  • Parallel Scavenge 使用复制算法,Parallel old 使用标记-整理算法

7.6. CMS

  • 并发标记和并发清除能够与用户线程一起执行。
  • 初始标记和重新标记 stop the work
  • 最短回收停顿时间
  • BS架构常用这种方式。
  • 单核CPU没有优势
  • 标记清除算法存在内存碎片

7.7. G1

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351

推荐阅读更多精彩内容