jvm

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

image.png

jvisualvm
图形化工具
安装插件和具体参数设置在网盘ppt中

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Java和C++之间有一堵由内存动态分配和垃圾收集技术所围成的“高墙”,墙外面的人想进来,墙里面的人想出来。 对象...
    胡二囧阅读 1,160评论 0 4
  • 作者:一字马胡 转载标志 【2017-11-12】 更新日志 日期更新内容备注 2017-11-12新建文章初版 ...
    beneke阅读 2,255评论 0 7
  • http://www.cnblogs.com/angeldevil/p/3801189.html值得一看 Clas...
    snail_knight阅读 1,499评论 1 0
  • 内存溢出和内存泄漏的区别 内存溢出:out of memory,是指程序在申请内存时,没有足够的内存空间供其使用,...
    Aimerwhy阅读 766评论 0 1
  • JVM架构 当一个程序启动之前,它的class会被类装载器装入方法区(Permanent区),执行引擎读取方法区的...
    cocohaifang阅读 1,739评论 0 7