Java GC

常用参数

非标准选项(以-X为前缀)不保证、也不强制所有JVM实现都必须支持

非稳定选项(以-XX为前缀)通常是为了特定需要而对JVM的运行进行校正

-XX:+PrintGCDetalis  打印GC信息

-XX:+PrintGCTimeStamps  打印每次GC的时间戳

-XX:+PrintHeapAtGC  每次GC时,打印堆信息

-XX:+PrintGCDateStamps  打印GC日期

-Xms  堆区的起始内存

-Xmx  堆区的最大内存

-XX:+DoEscapeAnalysis  开启逃逸分析

-XX:+PrintEscapeAnalysis  打印逃逸分析信息

逃逸回收实验

复制代码
public class FinalizeEscapeGC {
    public static FinalizeEscapeGC SAVE_HOOK=null;
    public void isAlive(){
        System.out.println("yes,i am still alive");
    }

    @Override
    protected void finalize() throws Throwable {
        super.finalize();
        System.out.println("finalize method executed!");
        FinalizeEscapeGC.SAVE_HOOK=this;
    }
    public static void main(String[] args) throws InterruptedException {
        SAVE_HOOK=new FinalizeEscapeGC();
        SAVE_HOOK=null;
        System.gc();
        Thread.sleep(500);
        if(SAVE_HOOK!=null){
            SAVE_HOOK.isAlive();
        }else {
            System.out.println("no,i am dead");
        }
        SAVE_HOOK=null;
        System.gc();
        Thread.sleep(500);
        if(SAVE_HOOK!=null){
            SAVE_HOOK.isAlive();
        }else {
            System.out.println("no,i am dead");
        }
    }
}
View Code
复制代码

使用-XX:+PrintGCDetalis

 

 

posted @   uptothesky  阅读(130)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· [AI/GPT/综述] AI Agent的设计模式综述
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
点击右上角即可分享
微信分享提示