型別修飾符volatile關鍵字

2021-06-16 09:08:02 字數 1437 閱讀 3936

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的變數是說 這變數可能會被意想不到地改變 這種意外不是...