[導(dǎo)讀]作者:LiamHuang最近在討論多線程編程中的一個(gè)可能的falsesharing問題時(shí),有人提出加volatile可能可以解決問題。這種錯(cuò)誤的認(rèn)識(shí)荼毒多年,促使我寫下這篇文章。約定Volatile這個(gè)話題,涉及到計(jì)算機(jī)科學(xué)多個(gè)領(lǐng)域多個(gè)層次的諸多細(xì)節(jié)。僅靠一篇博客,很難窮盡這些細(xì)...
作者:Liam Huang
最近在討論多線程編程中的一個(gè)可能的 false sharing 問題時(shí),有人提出加 volatile 可能可以解決問題。這種錯(cuò)誤的認(rèn)識(shí)荼毒多年,促使我寫下這篇文章。
約定
Volatile 這個(gè)話題,涉及到計(jì)算機(jī)科學(xué)多個(gè)領(lǐng)域多個(gè)層次的諸多細(xì)節(jié)。僅靠一篇博客,很難窮盡這些細(xì)節(jié)。因此,若不對(duì)討論范圍做一些約定,很容易就有諸多漏洞。到時(shí)誤人子弟,就不好了。以下是一些基本的約定:
1. 這篇博文討論的 volatile 關(guān)鍵字,是 C 和 C 語言中的關(guān)鍵字。Java 等語言中,也有 volatile 關(guān)鍵字。但它們和 C/C 里的 volatile 不完全相同,不在這篇博文的討論范圍內(nèi)。
2. 這篇博文討論的 volatile 關(guān)鍵字,是限定在 C/C 標(biāo)準(zhǔn)之下的。這也就是說,我們討論的內(nèi)容應(yīng)該是與平臺(tái)無關(guān)的,同時(shí)也是與編譯器擴(kuò)展無關(guān)的。
3. 相應(yīng)的,這篇文章討論的「標(biāo)準(zhǔn)」指的是 C/C 的標(biāo)準(zhǔn),而不是其他什么東西。
4. 我們希望編寫的代碼是 (1) 符合標(biāo)準(zhǔn)的,(2) 性能良好的,(3) 可移植的。這里 (1) 保證了代碼執(zhí)行結(jié)果的正確性,(2) 保證了高效性,(3) 體現(xiàn)了平臺(tái)無關(guān)性(以及編譯器擴(kuò)展等的無關(guān)性)。
含義
單詞 volatile 的含義
在談及 C/C 中的 volatile 關(guān)鍵字時(shí),總有人會(huì)拿 volatile 這個(gè)英文單詞的中文解釋說事。他們把 volatile 翻譯作「易變的」。但事實(shí)上,對(duì)于翻譯來說,很多時(shí)候目標(biāo)語言很難找到一個(gè)詞能夠反映源語言中單詞的全部含義和細(xì)節(jié)。此處「易變的」就無法做到這一點(diǎn)。
Volatile 的意思,若要詳細(xì)理解,還是應(yīng)該查閱權(quán)威的英英字典。在柯林斯高階學(xué)習(xí)詞典中,volatile 是這樣解釋的:
A situation that is volatile is likely to change suddenly and unexpectedly.
這里對(duì) volatile 的解釋有三個(gè)精髓的形容詞和副詞,體現(xiàn)了 volatile 的含義。
1. likely:可能的。這意味著被 volatile 形容的對(duì)象「有可能也有可能不」發(fā)生改變,因此我們不能對(duì)這樣的對(duì)象的狀態(tài)做出任何假設(shè)。
2. suddenly:突然地。這意味著被 volatile 形容的對(duì)象可能發(fā)生瞬時(shí)改變。
3. unexpectedly:不可預(yù)期地。這與 likely 相互呼應(yīng),意味著被 volatile 形容的對(duì)象可能以各種不可預(yù)期的方式和時(shí)間發(fā)生更改。
因此,volatile 其實(shí)就是告訴我們,被它修飾的對(duì)象出現(xiàn)任何情況都不要奇怪,我們不能對(duì)它們做任何假設(shè)。
程序中 volatile 的含義
對(duì)于程序員來說,程序本身的任何行為都必須是可預(yù)期的。那么,在程序當(dāng)中,什么才叫 volatile 呢?這個(gè)問題的答案也很簡單:程序可能受到程序之外的因素影響。
考慮以下 C/C 代碼。
volatile int *p = /* ... */;int a, b;a = *p;b = *p;
若忽略 volatile,那么 p 就只是一個(gè)「指向 int 類型的指針」。這樣一來,a = *p; 和 b = *p; 兩句,就只需要從內(nèi)存中讀取一次就夠了。因?yàn)閺膬?nèi)存中讀取一次之后,CPU 的寄存器中就已經(jīng)有了這個(gè)值;把這個(gè)值直接復(fù)用就可以了。這樣一來,編譯器就會(huì)做優(yōu)化,把兩次訪存的操作優(yōu)化成一次。這樣做是基于一個(gè)假設(shè):我們?cè)诖a里沒有改變 p 指向內(nèi)存地址的值,那么這個(gè)值就一定不會(huì)發(fā)生改變。
此處說的「讀取內(nèi)存」,包括了讀取 CPU 緩存和讀取計(jì)算機(jī)主存。
然而,由于 MMIP(Memory mapped I/O)的存在,這個(gè)假設(shè)不一定是真的。例如說,假設(shè) p 指向的內(nèi)存是一個(gè)硬件設(shè)備。這樣一來,從 p 指向的內(nèi)存讀取數(shù)據(jù)可能伴隨著可觀測的副作用:硬件狀態(tài)的修改。此時(shí),代碼的原意可能是將硬件設(shè)備返回的連續(xù)兩個(gè) int 分別保存在 a 和 b 當(dāng)中。這種情況下,編譯器的優(yōu)化就會(huì)導(dǎo)致程序行為不符合預(yù)期了。
總結(jié)來說,被 volatile 修飾的變量,在對(duì)其進(jìn)行讀寫操作時(shí),會(huì)引發(fā)一些可觀測的副作用。而這些可觀測的副作用,是由程序之外的因素決定的。
關(guān)鍵字 volatile 的含義
CPP reference 網(wǎng)站是對(duì) C 和 C 語言標(biāo)準(zhǔn)的整理。因此,絕大多數(shù)時(shí)候,我們可以通過這個(gè)網(wǎng)站對(duì)語言標(biāo)準(zhǔn)進(jìn)行查詢。關(guān)于 volatile 關(guān)鍵字,有 C 語言標(biāo)準(zhǔn)和 C 語言標(biāo)準(zhǔn)可查。這里摘錄兩份標(biāo)準(zhǔn)對(duì) volatile 訪問的描述。
C 語言:Every access (both read and write) made through an lvalue expression of volatile-qualified type is considered an observable side effect for the purpose of optimization and is evaluated strictly according to the rules of the abstract machine (that is, all writes are completed at some time before the next sequence point). This means that within a single thread of execution, a volatile access cannot be optimized out or reordered relative to another visible side effect that is separated by a sequence point from the volatile access.
C 語言:Every access (read or write operation, member function call, etc.) made through a glvalue expression of volatile-qualified type is treated as a visible side-effect for the purposes of optimization (that is, within a single thread of execution, volatile accesses cannot be optimized out or reordered with another visible side effect that is sequenced-before or sequenced-after the volatile access. This makes volatile objects suitable for communication with a signal handler, but not with another thread of execution, see std::memory_order). Any attempt to refer to a volatile object through a non-volatile glvalue (e.g. through a reference or pointer to non-volatile type) results in undefined behavior.
這里首先解釋兩組概念:值類型和序列點(diǎn)(執(zhí)行序列)。
值類型指的是左值(lvalue)右值(rvalue)這些概念。關(guān)于左值和右值,前作有過介紹。簡單的理解,左值可以出現(xiàn)在賦值等號(hào)的左邊,使用時(shí)取的是作為對(duì)象的身份;右值不可以出現(xiàn)在賦值等號(hào)的左邊,使用時(shí)取的是對(duì)象的值。除了 lvalue 和 rvalue,C 還定義了其他的值類型。其中,xvalue 大體可以理解為返回右值引用的函數(shù)調(diào)用或表達(dá)式,而 glvalue 則是 lvalue 和 xvalue 之和。
序列點(diǎn)則是 C/C 中討論執(zhí)行順序時(shí)會(huì)提到的概念。對(duì)于 C/C 的表達(dá)式來說,執(zhí)行表達(dá)式有兩種類型的動(dòng)作:(1) 計(jì)算某個(gè)值、(2) 副作用(例如訪問 volatile 對(duì)象,原子同步,修改文件等)。因此,如果在兩個(gè)表達(dá)式 E1 和 E2 中間有一個(gè)序列點(diǎn),或者在 C 中 E1 于序列中在 E2 之前,則 E1 的求值動(dòng)作和副作用都會(huì)在 E2 的求值動(dòng)作和副作用之前。關(guān)于序列點(diǎn)和序列順序規(guī)則,可以參考:這里和這里。
因此我們講,在 C/C 中,對(duì) volatile 對(duì)象的訪問,有編譯器優(yōu)化上的副作用:
1. 不允許被優(yōu)化消失(optimized out);
2. 于序列上在另一個(gè)對(duì) volatile 對(duì)象的訪問之前。
這里提及的「不允許被優(yōu)化」表示對(duì) volatile 變量的訪問,編譯器不能做任何假設(shè)和推理,都必須按部就班地與「內(nèi)存」進(jìn)行交互。因此,上述例中「復(fù)用寄存器中的值」就是不允許的。
需要注意的是,無論是 C 還是 C 的標(biāo)準(zhǔn),對(duì)于 volatile 訪問的序列性,都有單線程執(zhí)行的前提。其中 C 標(biāo)準(zhǔn)特別提及,這個(gè)順序性在多線程環(huán)境里不一定成立。
volatile 與多線程
volatile 可以解決多線程中的某些問題,這一錯(cuò)誤認(rèn)識(shí)荼毒多年。例如,在知乎「volatile」話題下的介紹就是「多線程開發(fā)中保持可見性的關(guān)鍵字」。為了撥亂反正,這里先給出結(jié)論(注意這些結(jié)論都基于本文第一節(jié)提出的約定之上):
1. volatile 不能解決多線程中的問題。
2. 按照 Hans Boehm
欲知詳情,請(qǐng)下載word文檔
下載文檔
本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。
關(guān)鍵字:
阿維塔
塞力斯
華為
加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...
關(guān)鍵字:
AWS
AN
BSP
數(shù)字化
倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...
關(guān)鍵字:
汽車
人工智能
智能驅(qū)動(dòng)
BSP
北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...
關(guān)鍵字:
亞馬遜
解密
控制平面
BSP
8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場的投資。
關(guān)鍵字:
騰訊
編碼器
CPU
8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。
關(guān)鍵字:
華為
12nm
EDA
半導(dǎo)體
8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。
關(guān)鍵字:
華為
12nm
手機(jī)
衛(wèi)星通信
要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...
關(guān)鍵字:
通信
BSP
電信運(yùn)營商
數(shù)字經(jīng)濟(jì)
北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...
關(guān)鍵字:
VI
傳輸協(xié)議
音頻
BSP
北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...
關(guān)鍵字:
BSP
信息技術(shù)
山海路引?嵐悅新程 三亞2024年8月27日 /美通社/ --?近日,海南地區(qū)六家凱悅系酒店與中國高端新能源車企嵐圖汽車(VOYAH)正式達(dá)成戰(zhàn)略合作協(xié)議。這一合作標(biāo)志著兩大品牌在高端出行體驗(yàn)和環(huán)保理念上的深度融合,將...
關(guān)鍵字:
新能源
BSP
PLAYER
ASIA
上海2024年8月28日 /美通社/ -- 8月26日至8月28日,AHN LAN安嵐與股神巴菲特的孫女妮可?巴菲特共同開啟了一場自然和藝術(shù)的療愈之旅。 妮可·巴菲特在療愈之旅活動(dòng)現(xiàn)場合影 ...
關(guān)鍵字:
MIDDOT
BSP
LAN
SPI
8月29日消息,近日,華為董事、質(zhì)量流程IT總裁陶景文在中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式上表示,中國科技企業(yè)不應(yīng)怕美國對(duì)其封鎖。
關(guān)鍵字:
華為
12nm
EDA
半導(dǎo)體
上海2024年8月26日 /美通社/ -- 近日,全球領(lǐng)先的消費(fèi)者研究與零售監(jiān)測公司尼爾森IQ(NielsenIQ)迎來進(jìn)入中國市場四十周年的重要里程碑,正式翻開在華發(fā)展新篇章。自改革開放以來,中國市場不斷展現(xiàn)出前所未有...
關(guān)鍵字:
BSP
NI
SE
TRACE
上海2024年8月26日 /美通社/ -- 第二十二屆跨盈年度B2B營銷高管峰會(huì)(CC2025)將于2025年1月15-17日在上海舉辦,本次峰會(huì)早鳥票注冊(cè)通道開啟,截止時(shí)間10月11日。 了解更多會(huì)議信息:cc.co...
關(guān)鍵字:
BSP
COM
AI
INDEX
上海2024年8月26日 /美通社/ -- 今日,高端全合成潤滑油品牌美孚1號(hào)攜手品牌體驗(yàn)官周冠宇,開啟全新旅程,助力廣大車主通過駕駛?cè)ヌ剿鞲鼜V闊的世界。在全新發(fā)布的品牌視頻中,周冠宇及不同背景的消費(fèi)者表達(dá)了對(duì)駕駛的熱愛...
關(guān)鍵字:
BSP
汽車制造
此次發(fā)布標(biāo)志著Cision首次為亞太市場量身定制全方位的媒體監(jiān)測服務(wù)。 芝加哥2024年8月27日 /美通社/ -- 消費(fèi)者和媒體情報(bào)、互動(dòng)及傳播解決方案的全球領(lǐng)導(dǎo)者Cis...
關(guān)鍵字:
CIS
IO
SI
BSP
上海2024年8月27日 /美通社/ -- 近來,具有強(qiáng)大學(xué)習(xí)、理解和多模態(tài)處理能力的大模型迅猛發(fā)展,正在給人類的生產(chǎn)、生活帶來革命性的變化。在這一變革浪潮中,物聯(lián)網(wǎng)成為了大模型技術(shù)發(fā)揮作用的重要陣地。 作為全球領(lǐng)先的...
關(guān)鍵字:
模型
移遠(yuǎn)通信
BSP
高通
北京2024年8月27日 /美通社/ -- 高途教育科技公司(紐約證券交易所股票代碼:GOTU)("高途"或"公司"),一家技術(shù)驅(qū)動(dòng)的在線直播大班培訓(xùn)機(jī)構(gòu),今日發(fā)布截至2024年6月30日第二季度未經(jīng)審計(jì)財(cái)務(wù)報(bào)告。 2...
關(guān)鍵字:
BSP
電話會(huì)議
COM
TE
8月26日消息,華為公司最近正式啟動(dòng)了“華為AI百校計(jì)劃”,向國內(nèi)高校提供基于昇騰云服務(wù)的AI計(jì)算資源。
關(guān)鍵字:
華為
12nm
EDA
半導(dǎo)體