java虚拟机的逃逸分析

逃逸分析作为其他优化手段提供依据的分析技术,其基本行为就是分析对象动态作用域:当一个对象在方法中被定义后,它可能被外部方法所引用,例如作为调用参数传递到其他方法中,称为方法逃逸。甚至还有可能被外部线程访问到,比如赋值给类变量或可以在其他线程中访问的实例变量,称为线程逃逸。
如果能证明一个对象不会逃逸到方法或线程之外,也就是别的方法或者线程无法通过任何途径访问到这个对象,则可能为这个变量进行一些高校的优化。
1)栈上分配,如果确定一个对象不会逃逸出方法之外,那么把这个对象在栈上分配内存,对象所占用的内存空间就可以随栈帧出栈而销毁。在一般应用中,不会逃逸的局部对象所占的比例很大,如果能够使用栈上分配,那么对象就会随着方法的结束而自动销毁,垃圾收集系统的压力将会小很多。
2)同步消除,线程同步本身就是一个相对耗时的过程,如果逃逸分析能够确定一个变量不会逃逸出线程,无法被其他线程访问,那这个变量的读写肯定就不会有竞争,对这个变量实施的同步操作也就可以消除掉。
3)标量替换:如果逃逸分析证明一个对象不会被外部访问。并且这个对象可以被拆散的话,那程序真正执行的时候可能不创建这个对象,而改为直接创建它的若干个被这个方法使用到的成员变量来替换。

原文地址:https://www.cnblogs.com/tiancai/p/9359749.html

时间: 2024-10-07 09:42:17

java虚拟机的逃逸分析的相关文章

深入理解Java中的逃逸分析

在Java的编译体系中,一个Java的源代码文件变成计算机可执行的机器指令的过程中,需要经过两段编译,第一段是把.java文件转换成.class文件.第二段编译是把.class转换成机器指令的过程. 第一段编译就是javac命令. 在第二编译阶段,JVM 通过解释字节码将其翻译成对应的机器指令,逐条读入,逐条解释翻译.很显然,经过解释执行,其执行速度必然会比可执行的二进制字节码程序慢很多.这就是传统的JVM的解释器(Interpreter)的功能.为了解决这种效率问题,引入了 JIT(即时编译)

java 虚拟机源码分析

?openjdk下载: 地址: http://hg.openjdk.java.net 下载openjdk7 Hotspot下的模块: Adlc: 平台描述文件 Libadt: 抽象数据结构 Asm: 汇编器 Code: 机器码生生成 C1: client编译器, 即C1编译器 Ci: 动态编译器 Compiler: 调用动态编译器的接口 Opto: Server编译器,即C2编译器 Shark: 基于LLVM实现的即时编译器 Interpreter: 解释器 Classfile: Class文件

JVM逃逸分析DoEscapeAnalysis

JVM逃逸分析 JVM有栈.堆.方法区.本地栈等组成 栈:每个方法被执行的时候都会同时创建一个栈帧用于存储局部变量表.操作栈.动态连接.方法出口等信息.每个方法被调用直至执行完成的过程,就对应着一个栈帧在虚拟机栈中从入栈到出栈的过程. 堆:当实例化对象时,会把对象分配到堆中,然后把指向该堆的引用压入栈中. 逃逸:当一个对象的指针被多个方法或线程引用时,我们称这个指针发生了逃逸,一般情况返回对象.对全局变量的肤质一般都会发生逃逸. 逃逸分析:用来分析这种逃逸现象的方法称为逃逸分析 逃逸分析优化-栈

Java虚拟机知识点【引用】

??Java虚拟机采用可达性分析算法来判断对象是否可以回收.可达性分析算法通过一系列的GC Roots对象作为起始点,向下搜索走过的路径称引用链,当一个对象到GC Roots没有任何的引用链时,证明对象是不可用的. Java中,可作为GC Roots的对象: 虚拟机栈中引用的对象 本地方法栈的JNI引用的对象 方法区静态属性引用的对象 方法区常量引用的对象 Java对引用进行了扩充,分为强引用.软引用.弱引用.虚引用四种. 强引用:(StrongReference) 强引用是使用最普遍的引用.如

Java虚拟机类加载机制——案例分析

原文出处: 朱小厮 在<Java虚拟机类加载机制>一文中详细阐述了类加载的过程,并举了几个例子进行了简要分析,在文章的最后留了一个悬念给各位,这里来揭开这个悬念.建议先看完<Java虚拟机类加载机制>这篇再来看这个,印象会比较深刻,如若不然,也没什么关系~~下面是程序代码: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 package jvm.cla

[转]Java内存对象的逃逸分析

逃逸分析英文作Escape Analysis.在计算机语言编译器优化原理中,逃逸分析是指分析指针动态范围的方法,它同编译器优化原理的指针分析和外形分析相关联. 当变量(或者对象)在方法中分配后,其指针有可能被返回或者被全局引用,这样就会被其他过程或者线程所引用,这种现象称作指针(或者引用)的逃逸(Escape). 在Java 并发编程书里有个例子程序清单3-7 谈到 this escape. 开始没有想明白, 仔细琢磨了些时间发现代码主要的问题是在建构函数中创建了一个匿名类,然后发布了这个匿名类

《深入理解Java虚拟机》调优案例分析与实战

上节学习回顾 在上一节当中,主要学习了Sun JDK的一些命令行和可视化性能监控工具的具体使用,但性能分析的重点还是在解决问题的思路上面,没有好的思路,再好的工具也无补于事. 本节学习重点 在书本上本节的主要内容是讲作者在工作过程中对调优的一些经验实战.对于我们读者来说,重点是学习作者分析解决问题的具体思路.当然不能离开书本的内容,作者利用的是上一节所介绍到的工具去解决他所遇到的问题.但本人的工作环境跟书本上的教程不一致,但思路大同小异.所以在本章的学习笔记当中,还是结合自身的情况,聊聊调优这事

Java虚拟机八 分析Java堆

常见的内存溢出的原因及其解决思路 1.堆溢出: 由于大量的对象都直接分配在堆上,因此它最有可能发生溢出.因为大量对象占据了堆空间,而这些对象都持有强引用,导致无法回收,当对象大小之和大于堆空间时就会发生溢出. 为了解决堆溢出错误,一方面可以使用-Xmx参数指定一个更大的堆空间,另一方面,由于堆空间不可能无限增长,通过MAT或者Visual VM等工具,分析找到大量占用堆空间的对象,并在应用程序上作出合理的优化也是十分必要的. 2.直接内存溢出 在Java的NIO(New IO)中,直接内存的使用

从Java虚拟机角度分析类的实例化顺序

1.首先展示一下实例代码(Son.java & Father.java) public class Father { public static int a=10;//父类的静态变量 static{//父类的静态代码块 a=20; } {//父类的构造代码块 a=30; } public Father() {//父类的构造方法 a=40; } } public class Son extends Father{ public static int s=10;//子类的静态变量 public in