volatile關鍵字是一種型別修飾符,遇到這個關鍵字宣告的變數,編譯器對訪問該變數的**就不再進行
優化,從而可以提供對特殊位址的穩定訪問。
使用該關鍵字的例子如下:
int volatile nvint;
當要求使用volatile 宣告的變數的值的時候,系統總是重新從它所在的記憶體讀取資料,即使它前面的指
令剛剛從該處讀取過資料。而且讀取的資料立刻被儲存。
例如:volatile int i=10;
int a = i;
。。。//其他**,並未明確告訴編譯器,對i進行過操作
int b = i;
volatile 指出 i是隨時可能發生變化的,每次使用它的時候必須從i的位址中讀取,因而編譯器生成的
彙編**會重新從i的位址讀取資料放在b中。而優化做法是,由於編譯器發現兩次從i讀資料的**之間
的**沒有對i進行過操作,它會自動把上次讀的資料放在b中。而不是重新從i裡面讀。這樣以來,如果
i是乙個暫存器變數或者表示乙個埠資料就容易出錯,所以說volatile可以保證對特殊位址的穩定訪問
注意,在vc6中,一般除錯模式沒有進行**優化,所以這個關鍵字的作用看不出來。下面通過插入彙編
**,測試有無volatile關鍵字,對程式最終**的影響:
首先用classwizard建乙個win32 console工程,插入乙個voltest.cpp檔案,輸入下面的**:
#include
void main()
int b = i;
printf("i= %d/n",b);}
然後,在除錯版本模式執行程式,輸出結果如下:
i = 10
i = 32
然後,在release版本模式執行程式,輸出結果如下:
i = 10
i = 10
輸出的結果明顯表明,release模式下,編譯器對**進行了優化,第二次沒有輸出正確的i值。
下面,我們把 i的宣告加上volatile關鍵字,看看有什麼變化:
#include
void main()
int b = i;
printf("i= %d/n",b);}
分別在除錯版本和release版本執行程式,輸出都是:
i = 10
i = 32
這說明這個關鍵字發揮了它的作用!
正確使用Volatile 變數總結
1.正確理解鎖的概念,就要理解兩個key point 原子性 atmatic 與可見性。synchronized在原子性和可見性上都很好,volatile 在原子性上沒有強約束,在可見性上和synchronized一樣 可見性是指一直變數的內容在乙個執行緒中修改後,其他執行緒或方法能否在下次訪問時訪...
volatile 變數使用指南
volatile 變數具有 synchronized 的可見性特性,但是不具備原子特性。這就是說執行緒能夠自動發現 volatile 變數的最新值。volatile 變數可用於提供執行緒安全,但是只能應用於非常有限的一組用例 多個變數之間或者某個變數的當前值與修改後值之間沒有約束。因此,單獨使用 v...
linux中使用volatile(附加變數型別)
1 自動變數就是在函式內部定義的變數,只在內部有效 2 所以允許其他函式定義相同的變數 3 他們都有自己的區域性,沒有連線性 4 自動變數分配記憶體就壓棧,函式返回時退棧 5 一般不作專門說明的區域性變數,均是自動變數,比如static說明 6 自動變數使用棧機制使用記憶體 1 記憶體中的位置 靜態...