[Java JVM] Hotspot GC研究- GC安全点 (Safepoint&Stop The World)

什么是safepoint

引用openjdk官网的一段话:

A point during program execution at which all GC roots are known and all heap object contents are consistent. From a global point of view, all threads must block at a safepoint before the GC can run.

意思就是一个点, 在这个点, 所有GC Root的状态都是已知并且heap里的对象是一致的; 在这个点进行GC时, 所有的线程都需要block住, 这就是(STW)Stop The World.


为什么需要safepoint

很明显safepoint是个让人不开心的东西, 线程都干不了活了, 怎么搞生产? 存在是因为需要, 我们知道java在语言级别提供了线程支持, 每个线程都是独立的执行单元. 堆里对象的引用关系抽象出来就是一副有向图(Directed graph), 图中的节点就是对象, 该对象被其他对象引用可以用该对象的入度(indegree)表示, 而对象的出度(outdegree)可以表示该对象对其他对象的引用, 当然, 对象也可以引用自身, 只要让其内部字段赋值为this就可以了.

有向图太复杂, 可以在脑海里构建出这么一副引用关系图, 最顶是root(先不管是不是GC Root), 通过引用的线指向其他对象, 如果不考虑对象之间交叉引用的话, 这就像是一串葡萄, 拿住了根, 就提起了所有活着的对象. 那么什么会引起这串葡萄的变化? 这就是我们平时见得再多不过的字段赋值操作了(且将参数传递也认为是赋值), 例如:

public class JavaTest {
   
    public static class DemoObject {
   
        String val1;
    }

    /**
     * @param args
     */
    public static voi
  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java的垃圾回收(Garbage Collection, GC)是由Java虚拟机(JVM)自动执行的内存管理机制。配置Java GC的主要目的是调整内存管理和垃圾回收策略,以达到更好的性能和内存利用率。 以下是一些常见的Java GCJVM配置选项: 1. 选择垃圾回收器(GC algorithm):Java提供了多种垃圾回收算法,如Serial GC、Parallel GC、CMS GC、G1 GC等。可以通过设置`-XX:+UseSerialGC`、`-XX:+UseParallelGC`、`-XX:+UseConcMarkSweepGC`、`-XX:+UseG1GC`等选项来指定使用的垃圾回收器。 2. 设置新生代和老年代大小:Java堆内存被分为新生代(Young Generation)和老年代(Old Generation),可以通过`-Xmn`选项设置新生代大小,通过`-Xmx`和`-Xms`选项设置堆最大和初始大小。 3. 调整垃圾回收的停顿时间:默认情况下,JVM会尽量减少垃圾回收过程对应用程序的停顿时间,但可能会牺牲一些吞吐量。可以通过`-XX:MaxGCPauseMillis`选项设置最大停顿时间。 4. 设置垃圾回收相关参数:可以通过一些参数来调整垃圾回收的行为,如`-XX:MaxTenuringThreshold`设置对象进入老年代的年龄阈值,`-XX:SurvivorRatio`设置新生代中Eden区和Survivor区的大小比例等。 5. 监控和调优:可以使用JVM提供的工具(如jstat、jconsole、jvisualvm等)来监控垃圾回收情况和内存使用情况,从而进行优化和调整。 需要注意的是,不同的应用程序和场景可能需要不同的GCJVM配置,具体的配置需要根据实际情况进行调整和优化。此外,建议在进行GCJVM配置调整时,先进行性能测试和监控,以确保配置的改变能够带来预期的效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值