欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JAVA中JVM的重排序詳細(xì)介紹

 更新時(shí)間:2014年05月05日 08:56:28   作者:  
重排序通常是編譯器或運(yùn)行時(shí)環(huán)境為了優(yōu)化程序性能而采取的對(duì)指令進(jìn)行重新排序執(zhí)行的一種手段。重排序分為兩類:編譯期重排序和運(yùn)行期重排序,分別對(duì)應(yīng)編譯時(shí)和運(yùn)行時(shí)環(huán)境

在并發(fā)程序中,程序員會(huì)特別關(guān)注不同進(jìn)程或線程之間的數(shù)據(jù)同步,特別是多個(gè)線程同時(shí)修改同一變量時(shí),必須采取可靠的同步或其它措施保障數(shù)據(jù)被正確地修改,這里的一條重要原則是:不要假設(shè)指令執(zhí)行的順序,你無(wú)法預(yù)知不同線程之間的指令會(huì)以何種順序執(zhí)行。

但是在單線程程序中,通常我們?nèi)菀准僭O(shè)指令是順序執(zhí)行的,否則可以想象程序會(huì)發(fā)生什么可怕的變化。理想的模型是:各種指令執(zhí)行的順序是唯一且有序的,這個(gè)順序就是它們被編寫在代碼中的順序,與處理器或其它因素?zé)o關(guān),這種模型被稱作順序一致性模型,也是基于馮·諾依曼體系的模型。當(dāng)然,這種假設(shè)本身是合理的,在實(shí)踐中也鮮有異常發(fā)生,但事實(shí)上,沒(méi)有哪個(gè)現(xiàn)代多處理器架構(gòu)會(huì)采用這種模型,因?yàn)樗窃谑翘托Я?。而在編譯優(yōu)化和CPU流水線中,幾乎都涉及到指令重排序。

編譯期重排序

編譯期重排序的典型就是通過(guò)調(diào)整指令順序,在不改變程序語(yǔ)義的前提下,盡可能減少寄存器的讀取、存儲(chǔ)次數(shù),充分復(fù)用寄存器的存儲(chǔ)值。

假設(shè)第一條指令計(jì)算一個(gè)值賦給變量A并存放在寄存器中,第二條指令與A無(wú)關(guān)但需要占用寄存器(假設(shè)它將占用A所在的那個(gè)寄存器),第三條指令使用A的值且與第二條指令無(wú)關(guān)。那么如果按照順序一致性模型,A在第一條指令執(zhí)行過(guò)后被放入寄存器,在第二條指令執(zhí)行時(shí)A不再存在,第三條指令執(zhí)行時(shí)A重新被讀入寄存器,而這個(gè)過(guò)程中,A的值沒(méi)有發(fā)生變化。通常編譯器都會(huì)交換第二和第三條指令的位置,這樣第一條指令結(jié)束時(shí)A存在于寄存器中,接下來(lái)可以直接從寄存器中讀取A的值,降低了重復(fù)讀取的開(kāi)銷。

重排序?qū)τ诹魉€的意義

現(xiàn)代CPU幾乎都采用流水線機(jī)制加快指令的處理速度,一般來(lái)說(shuō),一條指令需要若干個(gè)CPU時(shí)鐘周期處理,而通過(guò)流水線并行執(zhí)行,可以在同等的時(shí)鐘周期內(nèi)執(zhí)行若干條指令,具體做法簡(jiǎn)單地說(shuō)就是把指令分為不同的執(zhí)行周期,例如讀取、尋址、解析、執(zhí)行等步驟,并放在不同的元件中處理,同時(shí)在執(zhí)行單元EU中,功能單元被分為不同的元件,例如加法元件、乘法元件、加載元件、存儲(chǔ)元件等,可以進(jìn)一步實(shí)現(xiàn)不同的計(jì)算并行執(zhí)行。

流水線架構(gòu)決定了指令應(yīng)該被并行執(zhí)行,而不是在順序化模型中所認(rèn)為的那樣。重排序有利于充分使用流水線,進(jìn)而達(dá)到超標(biāo)量的效果。

確保順序性

盡管指令在執(zhí)行時(shí)并不一定按照我們所編寫的順序執(zhí)行,但毋庸置疑的是,在單線程環(huán)境下,指令執(zhí)行的最終效果應(yīng)當(dāng)與其在順序執(zhí)行下的效果一致,否則這種優(yōu)化便會(huì)失去意義。

通常無(wú)論是在編譯期還是運(yùn)行期進(jìn)行的指令重排序,都會(huì)滿足上面的原則。

Java存儲(chǔ)模型中的重排序

在Java存儲(chǔ)模型(Java Memory Model, JMM)中,重排序是十分重要的一節(jié),特別是在并發(fā)編程中。JMM通過(guò)happens-before法則保證順序執(zhí)行語(yǔ)義,如果想要讓執(zhí)行操作B的線程觀察到執(zhí)行操作A的線程的結(jié)果,那么A和B就必須滿足happens-before原則,否則,JVM可以對(duì)它們進(jìn)行任意排序以提高程序性能。

volatile關(guān)鍵字可以保證變量的可見(jiàn)性,因?yàn)閷?duì)volatile的操作都在Main Memory中,而Main Memory是被所有線程所共享的,這里的代價(jià)就是犧牲了性能,無(wú)法利用寄存器或Cache,因?yàn)樗鼈兌疾皇侨值?,無(wú)法保證可見(jiàn)性,可能產(chǎn)生臟讀。

volatile還有一個(gè)作用就是局部阻止重排序的發(fā)生,對(duì)volatile變量的操作指令都不會(huì)被重排序,因?yàn)槿绻嘏判颍挚赡墚a(chǎn)生可見(jiàn)性問(wèn)題。

在保證可見(jiàn)性方面,鎖(包括顯式鎖、對(duì)象鎖)以及對(duì)原子變量的讀寫都可以確保變量的可見(jiàn)性。但是實(shí)現(xiàn)方式略有不同,例如同步鎖保證得到鎖時(shí)從內(nèi)存里重新讀入數(shù)據(jù)刷新緩存,釋放鎖時(shí)將數(shù)據(jù)寫回內(nèi)存以保數(shù)據(jù)可見(jiàn),而volatile變量干脆都是讀寫內(nèi)存。

相關(guān)文章

  • 深入學(xué)習(xí)java內(nèi)存化和函數(shù)式協(xié)同

    深入學(xué)習(xí)java內(nèi)存化和函數(shù)式協(xié)同

    這篇文章主要介紹了深入學(xué)習(xí)java內(nèi)存化和函數(shù)式協(xié)同,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,,需要的朋友可以參考下
    2019-06-06
  • JVM的7種垃圾回收器(小結(jié))

    JVM的7種垃圾回收器(小結(jié))

    這篇文章主要介紹了JVM的7種垃圾回收器(小結(jié)),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • SpringCloud?Feign超詳細(xì)講解

    SpringCloud?Feign超詳細(xì)講解

    Feign是Netflix公司開(kāi)發(fā)的一個(gè)聲明式的REST調(diào)用客戶端;?Ribbon負(fù)載均衡、?Hystrⅸ服務(wù)熔斷是我們Spring?Cloud中進(jìn)行微服務(wù)開(kāi)發(fā)非?;A(chǔ)的組件,在使用的過(guò)程中我們也發(fā)現(xiàn)它們一般都是同時(shí)出現(xiàn)的,而且配置也都非常相似
    2022-10-10
  • Spring Boot Actuator監(jiān)控端點(diǎn)小結(jié)

    Spring Boot Actuator監(jiān)控端點(diǎn)小結(jié)

    這篇文章主要介紹了Spring Boot Actuator監(jiān)控端點(diǎn)小結(jié),需要的朋友可以參考下
    2017-06-06
  • Spring?boot2.0?日志集成方法分享(1)

    Spring?boot2.0?日志集成方法分享(1)

    這篇文章主要介紹了Spring?boot2.0?日志集成方法分享,Spring?Boot使用Apache的Commons?Logging作為內(nèi)部的日志框架,其僅僅是一個(gè)日志接口,在實(shí)際應(yīng)用中需要為該接口來(lái)指定相應(yīng)的日志實(shí)現(xiàn),下文日志實(shí)現(xiàn)詳情需要的小伙伴可以參考一下
    2022-04-04
  • Map映射LinkedHashSet與LinkedHashMap應(yīng)用解析

    Map映射LinkedHashSet與LinkedHashMap應(yīng)用解析

    這篇文章主要為大家介紹了Map映射LinkedHashSet與LinkedHashMap的應(yīng)用解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助祝大家多多進(jìn)步
    2022-03-03
  • 使用maven?shade插件解決項(xiàng)目版本沖突詳解

    使用maven?shade插件解決項(xiàng)目版本沖突詳解

    這篇文章主要為大家介紹了使用maven?shade插件解決項(xiàng)目版本沖突詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • Java異常類型及處理

    Java異常類型及處理

    這篇文章主要介紹了Java異常出現(xiàn)原因,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-07-07
  • java監(jiān)聽(tīng)器實(shí)現(xiàn)在線人數(shù)統(tǒng)計(jì)

    java監(jiān)聽(tīng)器實(shí)現(xiàn)在線人數(shù)統(tǒng)計(jì)

    這篇文章主要為大家詳細(xì)介紹了java監(jiān)聽(tīng)器實(shí)現(xiàn)在線人數(shù)統(tǒng)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • Java關(guān)鍵字、標(biāo)識(shí)符、常量、變量語(yǔ)法詳解

    Java關(guān)鍵字、標(biāo)識(shí)符、常量、變量語(yǔ)法詳解

    這篇文章主要為大家詳細(xì)介紹了Java關(guān)鍵字、標(biāo)識(shí)符、常量、變量等基礎(chǔ)語(yǔ)法,感興趣的小伙伴們可以參考一下
    2016-09-09

最新評(píng)論