1、前言知识铺垫数组
一、逃逸对象:在一个方法内建立的对象没有被外界引用则称该对象为未逃逸的对象。多线程
二、JDK1.6之后的HotSpot虚拟机支持运行时的对象逃逸分析。性能
三、JVM中的参数配置:spa
1 1)-XX:+PrintFlagsInitial --查看JVM中的默认参数信息 2 3 2)--XX:+DoEscapeAnalysis --开启对象的逃逸分析(JDK8中默认开启) 4 5 3)--XX:-DoEscapeAnalysis --关闭对象的逃逸分析 6 7 4)-XX:+PrintGC --输出GC的基本信息 8 9 5)-XX:+PrintGCDetails --输出GC的详细信息 10 11 6)-Xmx5m/-Xms5m --最大/最小堆配置
2、对象建立时的内存分配线程
一、对象建立时有可能分配在堆上也有可能分配在栈上。设计
二、方法内部建立的小对象而且没有逃逸可能分配在栈上。code
三、JDK8默认打开逃逸分析,对JVM的执行会有性能上的提升。对象
4、设计对象时,假如对象不会被多线程共享,多个方法共享,此时,对象的引用应该尽可能使用局部变量。blog
3、逃逸分析的开启与关闭对JVM执行性能的影响内存
首先,咱们先来看一个实例。
1 public class TestObjectInstance01 { 2 public static void main(String[] args) { 3 long start = System.currentTimeMillis(); 4 for (int i = 0; i < 100000000; i++) { 5 //调用alloc()方法 6 alloc(); 7 } 8 long end = System.currentTimeMillis(); 9 System.out.println("运行时间:"+(end-start)); 10 } 11 12 private static void alloc() { 13 //建立一个只能存储一个字节的数组对象 14 byte[] arr = new byte[1]; 15 arr[0] = 10; 16 } 17 }
咱们配置了JVM的最大/最小堆参数,并开启了逃逸分析:
-Xmx5m -Xms5m -XX:+DoEscapeAnalysis -XX:+PrintGC
运行结果:
接着咱们又关闭了逃逸分析:
-Xmx5m -Xms5m -XX:-DoEscapeAnalysis -XX:+PrintGC
运行结果:
结果分析:
咱们能够看到,开启逃逸分析时,JVM的运行性能要远高于未开启时。由于栈上分配的对象不须要启动GC来进行回收,当调用的方法出栈时,该对象会自动销毁。