定義變數時 使用volatile修飾的作用

2021-04-09 01:26:15 字數 1182 閱讀 9684

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 記憶體中的位置 靜態...