2021年6月22日星期二

Battle:你会TLAB,我会逃逸分析

"噔噔噔......"传来一阵敲门声,把我从美梦中惊醒了。

朦胧间听到有人在说话"阿Q,在家不?"

"来了来了",推门一看,原来是"赵信"兄弟。

「赵信」:自称常山赵子龙,一把三爪长枪耍的虎虎生风,见人上去就是一枪,人送外号"菊花信"。


TLAB

  • 尽管不是所有的对象实例都能够在TLAB中成功分配内存(因为它的空间比较小),但JVM明确是将TLAB作为内存分配的首选;
  • 一旦对象在TLAB空间分配内存失败时,JVM就会尝试着通过使用加锁机制确保数据操作的原子性,从而直接在Eden空间中分配内存。

「参数设置」

  • -XX:UseTLAB:设置是否开启TLAB空间;
  • -XX:TLABWasteTargetPercent:设置TLAB空间所占Eden空间的百分比大小,默认仅占1%;

堆是分配对象的唯一选择吗?

  1. 如果经过逃逸分析(Escape Analysis)后发现,一个对象并没有逃逸出方法,那么就可能被优化为栈上分配。这样就无需在堆上分配内存,也无须进行垃圾回收了。这也是最常见的堆外存储技术。
  2. 基于OpenJDK深度定制的TaoBaoVM,它创新的GCIH(GCinvisible heap)实现了堆外分配。将生命周期较长的Java对象从堆中移至堆外,并且GC不能管理GCIH内部的Java对象,以此达到降低GC的回收频率和提升GC的回收效率的目的。

「举例一」

public void method(){
    User user = new User();
    ...
    user = null;
}

user对象在方法内部声明,且在内部置为null,未被方法外的方法所引用,我们就说user对象没有发生逃逸。

「可以」分配到栈上,并随着方法的结束,栈空间也随之移除。

「举例二」

public static StringBuffer createStringBuffer(String s1,String s2){
    StringBuffer sb = new StringBuffer();
    sb.append(s1);
    sb.append(s2);
    return sb;
}

虽然sb对象在方法内部被定义,但是它又作为方法的返回对象,可被其它方法调用,我们就说sb对象发生了逃逸。

要想不发生逃逸,可以改造为:

public static String createStringBuffer(String s1,String s2){
    StringBuffer sb = new StringBuffer();
    sb.append(s1);
    sb.append(s2);
    return sb.toString();
}

JDK 6u23版本之后,HotSpot中默认开启了逃逸分析。

  • -XX:DoEscapeAnalysis:显式开启逃逸分析
  • -XX:+PrintEscapeAnalysis:查看逃逸分析的筛选结果

栈上分配

/**
 * 栈上分配测试
 * -Xmx1G -Xms1G -XX:-DoEscapeAnalysis -XX:+PrintGCDetails
 */
public class StackAllocation {
    public static void main(String[] args) {
        long start = System.currentTimeMillis();

        for (int i = 0; i < 10000000; i++) {
            alloc();
        }
       
        long end = System.currentTimeMillis();
        System.out.println("花费的时间为: " + (end - start) + " ms");
        //为了方便查看堆内存中对象个数,线程sleep
        try {
            Thread.sleep(1000000);
        } catch (InterruptedException e1) {
            e1.printStackTrace();
        }
    }

    private static void alloc() {
        //未发生逃逸
        User user = new User();
    }

    static class User {

    }
}

逃逸分析默认开启,也可以手动开启:-XX:+DoEscapeAnalysis

关闭逃逸分析

同步省略

我们都知道线程同步的代价是相当高的,同步的后果就是降低了并发性和性能。

JVM为了提高性能,在动态编译同步块的时候,JIT编译器可以借助逃逸分析来判断同步块所使用的锁对象是否只能够被一个线程访问。

如果符合条件,那么JIT编译器在编译这个同步块的时候就会取消对这部分代码的同步。这个取消同步的过程就叫同步省略,也叫锁消除。

「举例」

public class SynchronizedTest {
    public void method() {
        Object code = new Object();
        synchronized(code) {
            System.out.println(code);
        }
    }
    /**
    *代码中对code这个对象进行加锁,
    *但是code对象的生命周期只在method方法中
    *并不会被其他线程所访问控制,
    *所以在 JIT 编译阶段就会被优化掉。
    */
    
    //优化为
    public void method2() {
        Object code = new Object();
        System.out.println(code);
    }
}

在解释执行时这里仍然会有锁,但是经过服务端编译器的即时编译之后,这段代码就会忽略所有的同步措施而直接执行。

标量替换

  • 标量:不可被进一步分解的量,如JAVA的基本数据类型就是标量;
  • 聚合量:可以被进一步分解的量, 在JAVA中对象就是可以被进一步分解的聚合量。

聚合量可以分解成其它标量和聚合量。

标量替换,又名分离对象,即在JIT阶段,如果经过逃逸分析,发现一个对象不会被外界访问的话,那么经过JIT优化,就会把这个对象拆解成若干个其中包含的成员变量来替代。

「举例」

public class ScalarTest {
    public static void main(String[] args) {
        alloc();   
    }
    public static void alloc(){
        Point&......

原文转载:http://www.shaoqun.com/a/823674.html

跨境电商:https://www.ikjzd.com/

好东东网:https://www.ikjzd.com/w/1238

kk馆:https://www.ikjzd.com/w/1713

feedly:https://www.ikjzd.com/w/754


"噔噔噔......"传来一阵敲门声,把我从美梦中惊醒了。朦胧间听到有人在说话"阿Q,在家不?""来了来了",推门一看,原来是"赵信"兄弟。「赵信」:自称常山赵子龙,一把三爪长枪耍的虎虎生风,见人上去就是一枪,人送外号"菊花信"。TLAB尽管不是所有的对象实例都能够在TLAB中成功分配内存(因为它的空间比较小),但JVM明确是将TLAB作为内存分配的首选;一旦对象在TLAB空间分配内存失败时,JV
免费22天JS官方注册资料:https://www.ikjzd.com/tl/107615
韩国沉船事故详细报道(7/7):http://lady.shaoqun.com/m/a/46985.html
老婆的姐姐竟然裸身引诱我:http://lady.shaoqun.com/m/a/270629.html
一个㖭下面两个吃奶 美女把腿张开让男人使劲桶:http://lady.shaoqun.com/m/a/247532.html
漫画:当代男女机械行为列表:http://www.30bags.com/a/451911.html
横店有哪些购物的好去处?:http://www.30bags.com/a/418503.html
Listing优化之描述篇&卖点篇:https://www.ikjzd.com/tl/107613
自己在用的亚马逊运营表格:https://www.ikjzd.com/tl/107614
口述:老婆的男秘问我每周和老婆几次:http://lady.shaoqun.com/m/a/105021.html
男朋友在车里㖭比过程 放在里面一整天:http://www.30bags.com/m/a/249824.html
这辆货车原来是个巢穴!灵山一男一女失脚"车震":http://www.30bags.com/a/451909.html
别搞混了!你知道婚外情,出轨,约枪,背叛的区别和危害吗?:http://www.30bags.com/a/451910.html

没有评论:

发表评论