国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:34日期:2022-08-11 13:05:54
目錄循環(huán)展開和粗化鎖分析Assembly日志禁止Loop unrolling循環(huán)展開和粗化鎖

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

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

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

因?yàn)槊看窝h(huán)都需要做跳轉(zhuǎn)操作,所以為了提升效率,上面的代碼其實(shí)可以被優(yōu)化為下面的:

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

注意上面我們使用的是16進(jìn)制數(shù)字,至于為什么要使用16進(jìn)制呢?這是為了方便我們?cè)诤竺娴腶ssembly代碼中快速找到他們。

好了,我們?cè)僭?x += 0x51 的外面加一層synchronized鎖,看一下synchronized鎖會(huì)不會(huì)隨著loop unrolling展開的同時(shí)被粗化。

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

萬事具備,只欠我們的運(yùn)行代碼了,這里我們還是使用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。為啥要取消這個(gè)選項(xiàng)呢?因?yàn)槿绻谄蜴i的情況下,如果線程獲得鎖之后,在之后的執(zhí)行過程中,如果沒有其他的線程訪問該鎖,那么持有偏向鎖的線程則不需要觸發(fā)同步。

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

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

接下來就是見證奇跡的時(shí)刻了。

分析Assembly日志

我們運(yùn)行上面的程序,將會(huì)得到一系列的輸出。因?yàn)楸疚牟⒉皇侵v解Assembly語言的,所以本文只是大概的理解一下Assembly的使用,并不會(huì)詳細(xì)的進(jìn)行Assembly語言的介紹,如果有想深入了解Assembly的朋友,可以在文后留言。

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

先看C1-compiled nmethod:

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

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

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

中間有個(gè)add $0x51,%eax操作,對(duì)于著我們的代碼中的add操作。

可以看到C1—compiled nmethod中是沒有進(jìn)行Loop unrolling的。

我們?cè)倏纯碈2-compiled nmethod:

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

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

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

Benchmark              Mode  Cnt     Score     Error  Units

LockOptimization.test  avgt    5  5601.819 ± 620.017  ns/op

得分還不錯(cuò)。

禁止Loop unrolling

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

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

我們?cè)龠\(yùn)行一下上面的程序:

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

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

再看看運(yùn)行結(jié)果:

Benchmark              Mode  Cnt      Score      Error  Units

LockOptimization.test  avgt    5  20846.709 ± 3292.522  ns/op

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

以上就是詳解Java編譯優(yōu)化之循環(huán)展開和粗化鎖的詳細(xì)內(nèi)容,更多關(guān)于Java編譯優(yōu)化之循環(huán)展開和粗化鎖的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 国产成人最新毛片基地 | 日本韩国一级毛片中文字幕 | 成人三级毛片 | 亚洲精品久久久久中文 | 欧美日韩一日韩一线不卡 | 久99re视频9在线观看 | 国产精品久久久久一区二区三区 | 夜夜操影院 | 欧美8888| 99久久国内精品成人免费 | 亚洲天堂网在线视频 | 久久99精品九九九久久婷婷 | 在线观看久草视频 | 男女视频免费网站 | 欧美 日韩 国产 在线 | 国产成人免费福利网站 | 亚洲第3页 | 91成人在线视频 | 精品久久久久久中文字幕 | 国产uv1区二区三区 国产va免费精品高清在线观看 | 中文字幕日韩一区二区不卡 | 国产超薄肉色丝袜足j | 天堂中文资源在线8 | 一级毛片不卡 | 成人黄页网站 | 男人一进一出桶女人视频 | 伊人22综合| 久久精品在线观看 | 黄色毛片视频校园交易 | 99热精品在线观看 | 日产国产精品久久久久久 | 手机看片免费基地 | 久久频这里精品香蕉久久 | 欧美综合在线视频 | 国产成人精品一区 | 在线播放一级片 | 国产精品欧美一区二区三区 | 国产欧美日韩精品第三区 | 欧美在线一级毛片观看 | 92国产福利久久青青草原 | 亚洲国产系列 |