JVM - 堆内存调优

6.1 堆区差别

JDK 1.7堆内存

JDK1.8 堆内存

使用 IDEA 调整堆内存大小测试

堆内存调优

-Xms :设置初始分配大小,默认为物理内存的 “1/64”。
-Xmx :最大分配内存,默认为物理内存的 “1/4”。
-XX:+PrintGCDetails :输出详细的GC处理日志。

代码示例

package cn.guardwhy.jvm_02;

public class Demo01 {
    
    
    public static void main(String[] args) {
    
    
        // 1.返回虚拟机试图使用的最大内存
        long maxMemory = Runtime.getRuntime().maxMemory();  // 字节 1024 * 1024
        // 2.返回JVM的初始化总内存
        long totalMemory = Runtime.getRuntime().totalMemory();

        // 输出结果
        System.out.println("MAX_MEMORY=" + maxMemory + "字节\t" + (maxMemory/(double)1024/1024)+ "MB");
        System.out.println("TOTAL_MEMORY=" + totalMemory + "字节\t" + (totalMemory/(double)1024/1024)+ "MB");

        // 默认情况下: 分配的总内存是PC内存的1/4, 而初始化的内存是:1/64
    }
}

IDEA中进行JVM调优参数设置

默认的情况下分配的内存是总内存的 1/4,而初始化的内存为 1/64

-Xms1024m -Xmx1024m -XX:+PrintGCDetails

执行结果

元空间并不在虚拟机中,而是使用本地内存。

6.2 Dump内存快照

在运行java程序的时候,测试运行时占用内存情况,这时候就需要使用测试工具查看了。在idea中有这么一个插件JProfiler,一款性能瓶颈分析工具。
基本作用

  • 分析Dump文件,快速定位内存泄漏。
  • 获得堆中对象的统计数据,获得对象相互引用的关系。
  • 采用树形展现对象间相互引用的情况。

安装JProfiler

1、IDEA插件安装

2、安装JProfiler监控软件

下载地址

3、注册码

L-Larry_Lau@163.com#5481-ucjn4a16rvd98#6038
L-Larry_Lau@163.com#99016-hli5ay1ylizjj#27215

4、配置IDEA运行环境

5、选择你要分析的项目,点击JProfiler图标启动, 启动完成会自动弹出JProfiler窗口,在里面就可以监控自己的代码性能了。

代码测试

package cn.guardwhy.jvm_02;

import java.util.ArrayList;
/*
* -Xms 设置初始化内存分配大小 1/64
* -Xmx 设置最大分配内存, 默认1/4
* -XX:+PrintGCDetails 打印GC垃圾回收信息
* -XX:+HeapDumpOnOutOfMemoryError // OOM DUMP
*/
public class Demo02 {
    
    
    // 创建字节数组对象
    byte[] bytes = new byte[1*1024*1024]; // 1m = 1024k
    public static void main(String[] args) {
    
    
        ArrayList<Demo02> list = new ArrayList<>();
        // 定义计数器
        int count = 0;
        try {
    
    
            while (true){
    
    
                list.add(new Demo02());
                count = count + 1;
            }
        } catch (Error e) {
    
    
            System.out.println("总数:" + count);
            e.printStackTrace();
        }
    }
}

VM参数调试

-Xms1m -Xmx8m -XX:+HeapDumpOnOutOfMemoryError

执行结果

寻找文件

使用 Jprofiler 工具分析查看

双击这个文件使用 Jprofiler打开

最大的对象

具体错误

猜你喜欢

转载自blog.csdn.net/hxy1625309592/article/details/114580109