• JVM基础学习


    public class TestJVM {
    
        // 运行时数据区【方法区、堆、程序计数器、虚拟机栈、本地方法栈】
        private static int _1M = 1024 * 1024;
    
        public static void main(String[] args) {
        byte[] alloc1, alloc2, alloc3, alloc4, alloc5, alloc6, alloc7, alloc8;
        alloc1 = new byte[1 * _1M];
        alloc2 = new byte[2 * _1M];
        alloc3 = new byte[3 * _1M];
        alloc4 = new byte[4 * _1M];
        alloc5 = new byte[5 * _1M];
        alloc6 = new byte[6 * _1M];
    
        alloc2 = null;
        alloc7 = new byte[7 * _1M];
    
        }
    
        // 命令1:
        // -verbose:gc -Xms30M -Xmx30M -Xmn10M -XX:+PrintGCDetails
        // -XX:SurvivorRatio=8 -XX:+HeapDumpOnOutOfMemoryError
    
        // 命令2:
        // -verbose:gc -Xms30M -Xmx30M -XX:+PrintGCDetails
        // -XX:NewRatio=2 -XX:SurvivorRatio=8 -XX:+HeapDumpOnOutOfMemoryError
    
        // -verbose:gc 打印垃圾收集器的执行日志
        // -Xms30M 最小堆的大小
        // -Xmx30M 最大堆的大小
        // -Xmn10M 年轻代大小
        // -XX:NewRatio=2 JVM堆中的新生代与老年代的大小比例为1:2
        // -XX:SurvivorRatio=8 设置Eden与Survivor的大小比例,默认8:1
    
        // 根据以上参数得知改程序的虚拟机堆大小为30M,年轻代为10M,老年代为20M,
        // 其中年轻代中Eden=8M,From Survivor=To Survivor=1M
    
        // 备注:
        // 运行时内存与垃圾回收介绍:http://www.cnblogs.com/God-froest/p/jvm_1_3.html
        // 参数介绍:http://blog.csdn.net/shenzhen_liubin/article/details/7207236
        // OOM的样例:http://blog.csdn.net/cutesource/article/details/8244250
    }

    参考资料:

    《深入理解Java虚拟机》笔记

    JVM参数以及其含义

    运行时内存以及垃圾收集器

  • 相关阅读:
    tomcat与resin的比较
    Linux Resin 安装配置
    [BZOJ3456]城市规划
    ZJOI 2017 仙人掌
    「LibreOJ NOI Round #1」动态几何问题
    [SDOI2015]约数个数和
    codeforce 940F
    codeforce 940F
    codeforce 940E
    [NOI2009]植物大战僵尸
  • 原文地址:https://www.cnblogs.com/xiaoxian1369/p/4321908.html
Copyright © 2020-2023  润新知