cmd java
HotSpot:
jvm 的核心组件 有个功能 就是经常编译的东西可以保存起来 类似于缓存
对class 的解析和编译
client:
默认
客户桌面级操作系统 分配的内存较小
server:
jre/lib/i386 配置文件里改顺序 jvm.cfg
分配的空间大
jvm基本结构
- 类加载子系统:
就包含了类加载器 加载后 放在方法区的空间 - 方法区
- 堆
大小由jvm控制
所有实例在这里创建
所有线程共享 - 直接内存
受限于物理内存的大小
在堆之外 不受限于堆 运行nio 的东西 - 垃圾回收系统
可以回收堆和直接内存和方法区 - java栈
方法压栈 保存点战争 - 本地方法栈
native method
就是不同的操作系统可以调用的本地方法不同 - pc 寄存器
一个java 线程创建一个pc寄存器
当前方法
指向被执行的指令 (java方法)
或者undefined (本地方法) - 执行引擎
就是hotsport 类似
可以即时编译
jvm 堆结构和分代
提高内存分配和垃圾回收的效率
堆的分代
新生代 老年代 永久代
堆:
young
eden +from +to
old
permanent
分代不同的垃圾回收
8 :1:1
minor gc :回收
垃圾回收达到阈值 会把from 清空 对象复制到to
垃圾回收算法
- 引用计数 引用为0 这清除
缺点 循环引用不能解决 - 复制算法
from to
回收的 复制的 没使用的 -----to复制的 - 标记清除法
要暂停这个应用 产生碎片
第一阶段 标记 有引用的对象
第二阶段 回收空对象 - 标记整理
没有碎片
垃圾收集器
gc算法的实现
scavenge 次收集器
对Eden 收集
在新生代
full gc 全收集器
触发 在young 无法回收时触发
老年代的gc
System.gc()
分代回收器
在运行的时候加上 垃圾收集器可以选
新生代的
- serial 串行 (次收集器)
- parnew 并行收集器
适用于 多核cpu
缩短了暂停时间点
是cms (老年代的一个收集器)的默认收集器
cms ---------------parnew /serial - parallel scavenge
并行 用复制算法
提高 吞吐量 = 用户代码时间/用户代码+gc时间
老年代的
-
serial old----------------------parnew /serial/ parallel scavenge
标记整理算法 -
parallel scavenge--------- parallel scavenge
并行: parallel
不包含用户线程
并发: cms
包含用户线程 -
cms ---------------parnew /serial
跨年代的
jvm 小工具
bin 目录下
jps -l
jps -v
看jvm 中的线程 有个pid
类是Linux中的ps
jstat
看jvm 运行时的信息
如 jstat -gc 3200 250 20
3200是 jps 看的线程id
jvisualvm
图形化工具
安装插件和具体参数设置在网盘ppt中
网友评论