深入理解Java虚拟机 总结

内存分布
1 程序计数器 : 记录JVM 运行指令的位置,线程独立

2  栈 线程独立,主要是局部变量、操作数

3 堆  线程共享
4 方法区 : 线程共享:类信息、常量、静态常量, 就是编译后的代码等数据

 


内存回收方法:

标记-清除算法(存活对象、可回收、未使用), 最基本的算法,内存碎片太多

复制算法( 保留 两份,一份使用,一份冗余):新生代 基本使用此方法; IBM 研究表明 新生代内存 中98% 的对象都会朝生夕死 ,所以Eden 区 : survivor 区 为8:1;

标记整理算法: 先标记,然后将存活对象 移动到一端,然后直接清理当前端

垃圾收集器

 

新生代收集器
Serial 收集器:  单线程收集, 收集时 Stop the world ,主要用在 Client 模式的应用中 ()

ParNew 收集器: 多线程收集,其余与Serial 类似,也是stop the world; Server 端 用的比较多,主要是 只有他能与 CMS 配合工作

Parallel scavenge 收集器(吞吐量优先): 也是并行使用copy 算法进行收集,但是其不stop the world;而是可以保留 部分用户吞吐量

老年代收集器
    Serial old 收集器:标记 整理, 也是stop the wold ,主要用于client 模式,效率高
Parallel old 收集器: Parallel scavenge 的老年代版本,使用标记-整理算法
CMS 收集器(Concurrent Mark Sweep): 最短回收停顿时间; 标记-清除算法


G1 收集器:标记-整理或者 复制算法; 

 

问题定位:
  jps -l  查看进程以及对应的 启动jar 包
  jps -v 查看jvm 启动参数
 

  jstat -gc 27280  2000 10 
  jstat -gcutil 27280 2000 10 
  jstat -options 可以查看所有的选项

  jinfo 查看或者调整虚拟机运行参数
   jinfo -flags 27280   查看所有参数
   jinfo -flag ConcGCThreads 23728    查看具体某个参数

 jmap 主要用于生成堆快照
 jmap -dump:live,format=b,file=/tmp/23728_2.prof  23728  
  (jhat 23728_2.prof 可以解析此dump 文件, 生成一个服务器,使用localhost:7000 查看对应数据, 关注 Show heap histogram )

   
jstack -l 23728 查看 线程堆栈

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值