java1.7 内存 逃逸分析_jvm逃逸分析(-XX:+DoEscapeAnalysis)

package gc;

/**

* -Xmx8m -Xms8m -XX:+PrintGC -XX:+DoEscapeAnalysis

*

* @author Rainfyl

*

*/

public class GCTest1 {

private static void alloc() {

byte[] bytes = new byte[2];

bytes[0] = 1;

}

public static void main(String[] args) {

long start = System.currentTimeMillis();

System.out.println(start);

for (int i = 0; i < 1000000000; i++) {

alloc();

}

System.out.println(System.currentTimeMillis() - start);

}

}

逃逸:当一个对象的指针被多个方法或线程引用时,我们称这个指针发生了逃逸,一般情况返回对象、对全局变量的赋值一般都会发生逃逸。

逃逸分析:用来分析这种逃逸现象的方法称为逃逸分析

逃逸分析优化-栈上分配:栈上分配的意思是方法内局部变量(未发生逃逸)生成的实例在栈上分配,不用在堆中分配,分配完成后,继续在调用栈内执行,最后线程结束,栈空间被回收,局部变量对象也被回收。

没有加逃逸分析:

.......

[GC (Allocation Failure)  2124K->588K(7680K), 0.0001805 secs]

[GC (Allocation Failure)  2124K->588K(7680K), 0.0001549 secs]

[GC (Allocation Failure)  2124K->588K(7680K), 0.0002598 secs]

[GC (Allocation Failure)  2124K->588K(7680K), 0.0003025 secs]

[GC (Allocation Failure)  2124K->588K(7680K), 0.0003102 secs]

[GC (Allocation Failure)  2124K->588K(7680K), 0.0002052 secs]

[GC (Allocation Failure)  2124K->588K(7680K), 0.0001924 secs]

[GC (Allocation Failure)  2124K->588K(7680K), 0.0002133 secs]

[GC (Allocation Failure)  2124K->588K(7680K), 0.0002278 secs]

9030

加了逃逸分析:

[GC (Allocation Failure)  1536K->568K(7680K), 0.0007765 secs]

[GC (Allocation Failure)  2104K->584K(7680K), 0.0006076 secs]

[GC (Allocation Failure)  2120K->600K(7680K), 0.0005939 secs]

6

在时间上差异明显

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值