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工程,插入乙個test.cpp檔案,輸入下面的**:
>>
#include "stdafx.h"
#include int main(int argc, char* argv)
int b = i;
printf("i=%d\n", b);
getchar();
return 0;
}
然後,在除錯版本模式執行程式,輸出結果如下:
i = 10
i = 32
然後,在release版本模式執行程式,輸出結果如下:
i = 10
i = 10
輸出的結果明顯表明,release模式下,編譯器對**進行了優化,第二次沒有輸出正確的i值。
下面,我們把i的宣告加上volatile關鍵字,看看有什麼變化:
#include "stdafx.h"
#include int main(int argc, char* argv)
int b = i;
printf("i=%d\n", b);
getchar();
return 0;
}
分別在debug版本和release版本執行程式,輸出都是:
i = 10
i = 32
這說明這個關鍵字發揮了它的作用!
volatile型別修飾符的作用
volatile關鍵字是一種型別修飾符,用它宣告的型別變數表示可以被某些編譯器未知的因素更改,比如 作業系統 硬體或者其它執行緒等。遇到這個關鍵字宣告的變數,編譯器對訪問該變數的 就不再進行優化,從而可以提供對特殊位址的穩定訪問。使用該關鍵字的例子如下 int volatile nvint 當要求使...
volatile型別修飾符的使用
儘管c和c 標準對於執行緒都明顯的 保持沉默 但它們以volatile關鍵字的形式,確實為多執行緒保留了一點特權。就象大家更熟悉的const一樣,volatile是乙個型別修飾符 type modifier 它是被設計用來修飾被不同執行緒訪問和修改的變數。如果沒有volatile,基本上會導致這樣的...
關於volatile修飾符
volatile是乙個型別修飾符 type specifier 它是被設計用來修飾被不同執行緒訪問和修改的變數。如果沒有volatile,基本上會導致這樣的結果 要麼無法編寫多執行緒程式,要麼使編譯器失去大量優化的機會。乙個定義為volatile的變數是說 這變數可能會被意想不到地改變 這種意外不是...