jvm学习笔记

本文探讨如何通过调整Java虚拟机参数来减少Minor GC频率,提高效率,并介绍降低Full GC的策略,如控制大对象生成、扩大堆内存和选择CMS或G1等高效回收器。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

jvm调优

  1. 降低 Minor GC 频率
    增加Eden区大小,扩容后,Minor GC 时增加了 T1,但省去了 T2 的时间。通常在虚拟机中,复制对象的成本要远高于扫描成本。
  2. 降低 Full GC 的频率
    1)减少创建大对象;2)增大堆内存空间;3)选择合适的 GC 回收器,比如CMS和G1中断时间是可预期的

在这里插入图片描述

  • Heap
    堆是 JVM 内存中最大的一块内存空间,该内存被所有线程共享,几乎所有对象和数组都被分配到了堆内存中。
    在这里插入图片描述

  • 程序计数器(Program Counter Register)
    程序计数器是一块很小的内存空间,主要用来记录各个线程执行的字节码的地址,例如,分支、循环、跳转、异常、线程恢复等都依赖于计数器。

  • 方法区(Method Area)
    方法区主要是用来存放已被虚拟机加载的类相关信息,包括类信息、运行时常量池、字符串常量池。类信息又包括了类的版本、字段、方法、接口和父类等信息。

  • 虚拟机栈(VM stack)
    Java 虚拟机栈是线程私有的内存空间,它和 Java 线程一起创建。当创建一个线程时,会在虚拟机栈中申请一个线程栈,用来保存方法的局部变量、操作数栈、动态链接方法和返回地址等信息,并参与方法的调用和返回。每一个方法的调用都伴随着栈帧的入栈操作,方法的返回则是栈帧的出栈操作。

  • 本地方法栈(Native Method Stack)
    本地方法栈跟 Java 虚拟机栈的功能类似,Java 虚拟机栈用于管理 Java 函数的调用,而本地方法栈则用于管理本地方法的调用。但本地方法并不是用 Java 实现的,而是由 C 语言实现的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值