JVM

内存结构

jvm内存结构

方法区(Method Area):
虚拟机栈(VM Stack):
一个线程一个栈,一个方法一个栈帧。
本地方法(Native Method Stack):
堆(Heap):
程序计算器(Program Counter Register):

堆内存

堆内存结构

堆内存包括新生代(new)和老年代(old)
新生代分一个eden和两个survivor(幸存者)
老年代分tenured

垃圾对象

什么是垃圾对象?
如何确定垃圾对象?
引用计数:存在有循环引用的问题。
正向可达:从roots对象计算可以到达的对象。

垃圾收集算法

Mark-Sweep标记清除

标记清除

问题:碎片化

Copying复制

Copying复制

问题:浪费内存
新生代应该比较多。survivor两个之间相互copy

Mark-Compact标记压缩

Mark-Compact标记压缩

问题:效率比copy略低
老年代应用比较多。

新生代(new):存活对象少,使用copying算法,占用内存空间也不大,效率高。
老年代(old):垃圾少,一般使用mark-copact。

垃圾收集器

  1. Serial Collector(串行垃圾回收器)
    1. 单线程
    2. -XX:+UseSerialGC
  2. Parallel Collector(并行垃圾回收器)
    1. 多线程,并发量大,不过每次垃圾收集,jvm要暂停
    2. -XX:UseParallelGC
  3. CMS Collector(并发垃圾回收器)
    1. XX:+USeParNewGC
    2. 多线程,并发量大,GC线程和应用线程都在运行
  4. G1(垃圾回收器)
    1. 不仅停顿短,同时并发量大
    2. –XX:+UseG1GC

jvm参数

1、-:标准参数,所有jvm都应该支持
2、-X:非标准,每个jvm实现都不同
3、-XX:不稳定参数,下一个版本可能会取消

java对象的分配

  1. 栈上分配
    1. 线程私有小对象
    2. 无逃逸
    3. 支持标量替换
    4. 无需调整
  2. 线程本地分配TLAB(Thread Local Allcation Buffer)
    1. 占用eden、默认1%
    2. 多线程的时候不用竞争eden就可以申请空间,提高效率
    3. 小对象
    4. 无需调整
  3. 老年代
    1. 大对象
  4. eden

jvm调优

  1. 线程大小(栈内存大小)
    设置:Xss:128
    栈内存越大,栈帧数量就越多,方法调用就越深,但线程并发量就少
    栈内存越小,栈帧数量就越少,方法调用就越浅,但线程并发量就多

持久加压,测峰值

jmx

使用工具

visualvm:java内存监控;
jvisualvm.exe:java自动工具,bin目录下。

apache-jmeter:请求模拟工具。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1.一些概念 1.1.数据类型 Java虚拟机中,数据类型可以分为两类:基本类型和引用类型。基本类型的变量保存原始...
    落落落落大大方方阅读 10,180评论 4 86
  • Java 虚拟机有自己完善的硬件架构, 如处理器、堆栈、寄存器等,还具有相应的指令系统。JVM 屏蔽了与具体操作系...
    尹小凯阅读 5,626评论 0 10
  • JVM架构 当一个程序启动之前,它的class会被类装载器装入方法区(Permanent区),执行引擎读取方法区的...
    cocohaifang阅读 5,696评论 0 7
  • 转载blog.csdn.net/ning109314/article/details/10411495/ JVM工...
    forever_smile阅读 10,758评论 1 56
  • 原文阅读 前言 这段时间懈怠了,罪过! 最近看到有同事也开始用上了微信公众号写博客了,挺好的~给他们点赞,这博客我...
    码农戏码阅读 11,238评论 2 31

友情链接更多精彩内容