亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解Java編譯優(yōu)化之循環(huán)展開和粗化鎖

 更新時間:2021年06月02日 14:14:54   作者:flydean  
之前在講JIT的時候,有提到在編譯過程中的兩種優(yōu)化循環(huán)展開和粗化鎖,今天從Assembly的角度來驗證一下這兩種編譯優(yōu)化方法,快來看看吧。

循環(huán)展開和粗化鎖

我們先來回顧一下什么是循環(huán)展開。

循環(huán)展開就是說,像下面的循環(huán)遍歷的例子:

for (int i = 0; i < 1000; i++) {
    x += 0x51;
}

因為每次循環(huán)都需要做跳轉(zhuǎn)操作,所以為了提升效率,上面的代碼其實可以被優(yōu)化為下面的:

for (int i = 0; i < 250; i++) {
    x += 0x144; //0x51 * 4
}

注意上面我們使用的是16進制數(shù)字,至于為什么要使用16進制呢?這是為了方便我們在后面的assembly代碼中快速找到他們。

好了,我們再在 x += 0x51 的外面加一層synchronized鎖,看一下synchronized鎖會不會隨著loop unrolling展開的同時被粗化。

for (int i = 0; i < 1000; i++) {
    synchronized (this) {
        x += 0x51;
    }
}

萬事具備,只欠我們的運行代碼了,這里我們還是使用JMH來執(zhí)行。

相關(guān)代碼如下:

@Warmup(iterations = 10, time = 1, timeUnit = TimeUnit.SECONDS)
@Measurement(iterations = 5, time = 1, timeUnit = TimeUnit.SECONDS)
@Fork(value = 1,
        jvmArgsPrepend = {
        "-XX:-UseBiasedLocking",
                "-XX:CompileCommand=print,com.flydean.LockOptimization::test"
}
        )
@State(Scope.Benchmark)
@BenchmarkMode(Mode.AverageTime)
@OutputTimeUnit(TimeUnit.NANOSECONDS)
public class LockOptimization {

    int x;
    @Benchmark
    @CompilerControl(CompilerControl.Mode.DONT_INLINE)
    public void test() {
        for (int i = 0; i < 1000; i++) {
            synchronized (this) {
                x += 0x51;
            }
        }
    }

    public static void main(String[] args) throws RunnerException {
        Options opt = new OptionsBuilder()
                .include(LockOptimization.class.getSimpleName())
                .build();
        new Runner(opt).run();
    }
}

上面的代碼中,我們?nèi)∠似蜴i的使用:-XX:-UseBiasedLocking。為啥要取消這個選項呢?因為如果在偏向鎖的情況下,如果線程獲得鎖之后,在之后的執(zhí)行過程中,如果沒有其他的線程訪問該鎖,那么持有偏向鎖的線程則不需要觸發(fā)同步。

為了更好的理解synchronized的流程,這里我們將偏向鎖禁用。

其他的都是我們之前講過的JMH的常規(guī)操作。

接下來就是見證奇跡的時刻了。

分析Assembly日志

我們運行上面的程序,將會得到一系列的輸出。因為本文并不是講解Assembly語言的,所以本文只是大概的理解一下Assembly的使用,并不會詳細的進行Assembly語言的介紹,如果有想深入了解Assembly的朋友,可以在文后留言。

分析Assembly的輸出結(jié)果,我們可以看到結(jié)果分為C1-compiled nmethod和C2-compiled nmethod兩部分。

先看C1-compiled nmethod:

第一行是monitorenter,表示進入鎖的范圍,后面還跟著對于的代碼行數(shù)。

最后一行是monitorexit,表示退出鎖的范圍。

中間有個add $0x51,%eax操作,對于著我們的代碼中的add操作。

可以看到C1—compiled nmethod中是沒有進行Loop unrolling的。

我們再看看C2-compiled nmethod:

和C1很類似,不同的是add的值變成了0x144,說明進行了Loop unrolling,同時對應(yīng)的鎖范圍也跟著進行了擴展。

最后看下運行結(jié)果:

Benchmark              Mode  Cnt     Score     Error  Units

LockOptimization.test  avgt    5  5601.819 ± 620.017  ns/op

得分還不錯。

禁止Loop unrolling

接下來我們看下如果將Loop unrolling禁掉,會得到什么樣的結(jié)果。

要禁止Loop unrolling,只需要設(shè)置-XX:LoopUnrollLimit=1即可。

我們再運行一下上面的程序:

可以看到C2-compiled nmethod中的數(shù)字變成了原本的0x51,說明并沒有進行Loop unrolling。

再看看運行結(jié)果:

Benchmark              Mode  Cnt      Score      Error  Units

LockOptimization.test  avgt    5  20846.709 ± 3292.522  ns/op

可以看到運行時間基本是優(yōu)化過后的4倍左右。說明Loop unrolling還是非常有用的。

以上就是詳解Java編譯優(yōu)化之循環(huán)展開和粗化鎖的詳細內(nèi)容,更多關(guān)于Java編譯優(yōu)化之循環(huán)展開和粗化鎖的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 淺談Java的LinkedHashSet源碼

    淺談Java的LinkedHashSet源碼

    這篇文章主要介紹了淺談Java的LinkedHashSet源碼,底層是鏈表實現(xiàn)的,是set集合中唯一一個能保證怎么存就怎么取的集合對象
    因為是HashSet的子類,所以也是保證元素唯一的,與HashSet的原理一樣,需要的朋友可以參考下
    2023-09-09
  • Java Math.round函數(shù)詳解

    Java Math.round函數(shù)詳解

    這篇文章主要介紹了Java Math.round函數(shù)詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Java爬取網(wǎng)站源代碼和鏈接代碼實例

    Java爬取網(wǎng)站源代碼和鏈接代碼實例

    這篇文章主要介紹了Java爬取網(wǎng)站源代碼和鏈接代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • Mybatis動態(tài)sql超詳細講解

    Mybatis動態(tài)sql超詳細講解

    動態(tài)SQL是MyBatis的強大特性之一,顧名思義就是會動的SQL,即是能夠靈活的根據(jù)某種條件拼接出完整的SQL語句,下面這篇文章主要給大家介紹了關(guān)于Mybatis動態(tài)sql的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • 五個很實用的IDEA使用技巧分享

    五個很實用的IDEA使用技巧分享

    IntelliJ IDEA 是一款優(yōu)秀的 Java 集成開發(fā)環(huán)境,它提供了許多強大的功能和快捷鍵,可以幫助開發(fā)者提高編碼效率和質(zhì)量,本文就在為你介紹博主常用的五個IntelliJ IDEA使用技巧,希望能夠給你帶來一些工作效率上的提升
    2023-10-10
  • Java8 HashMap擴容算法實例解析

    Java8 HashMap擴容算法實例解析

    這篇文章主要介紹了Java8 HashMap擴容算法實例解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-12-12
  • Java實現(xiàn)四則混合運算代碼示例

    Java實現(xiàn)四則混合運算代碼示例

    這篇文章主要介紹了Java實現(xiàn)四則混合運算代碼示例,文中展示了詳細代碼,具有一定參考價值,需要的朋友可以了解下。
    2017-10-10
  • 實例講解Java的Spring框架中的AOP實現(xiàn)

    實例講解Java的Spring框架中的AOP實現(xiàn)

    這篇文章主要介紹了Java的Spring框架中的AOP實現(xiàn)實例,AOP面向切面編程其實也可以被看作是一個設(shè)計模式去規(guī)范項目的結(jié)構(gòu),需要的朋友可以參考下
    2016-04-04
  • commons io文件操作示例分享

    commons io文件操作示例分享

    這篇文章主要介紹了commons io文件操作示例分享,需要的朋友可以參考下
    2014-02-02
  • SpringBoot+Mybatis使用Enum枚舉類型總是報錯No enum constant XX問題

    SpringBoot+Mybatis使用Enum枚舉類型總是報錯No enum constant&n

    這篇文章主要介紹了SpringBoot+Mybatis使用Enum枚舉類型總是報錯No enum constant XX問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12

最新評論