volatile用于防止編譯器優(yōu)化變量訪(fǎng)問(wèn),確保每次讀寫(xiě)都從內(nèi)存進(jìn)行,適用于硬件寄存器、信號(hào)處理和可能被外部修改的變量,但不保證原子性或線(xiàn)程安全,多線(xiàn)程場(chǎng)景應(yīng)使用std::atomic。
volatile 是 C++ 中的一個(gè)類(lèi)型修飾符,用來(lái)告訴編譯器:被它修飾的變量可能會(huì)在程序的控制之外被改變,因此不能對(duì)該變量的訪(fǎng)問(wèn)進(jìn)行優(yōu)化。編譯器在遇到 volatile 變量時(shí),必須每次都從內(nèi)存中讀取其值,而不是使用寄存器中可能緩存的副本。
volatile 關(guān)鍵字的核心作用是禁止編譯器對(duì)變量訪(fǎng)問(wèn)進(jìn)行優(yōu)化。具體來(lái)說(shuō):
加上 volatile 后,編譯器會(huì)確保每次訪(fǎng)問(wèn)都從原始內(nèi)存地址讀取或?qū)懭?,避免此?lèi)問(wèn)題。
在嵌入式系統(tǒng)或驅(qū)動(dòng)開(kāi)發(fā)中,常常需要訪(fǎng)問(wèn)特定內(nèi)存地址表示的硬件寄存器。這些寄存器的值可能隨時(shí)由硬件改變。
立即學(xué)習(xí)“C++免費(fèi)學(xué)習(xí)筆記(深入)”;
例如:
volatile int* hardware_reg = reinterpret_cast<volatile int*>(0x12345678); int val = *hardware_reg; // 每次都從地址讀取,不會(huì)被優(yōu)化掉
2. 信號(hào)處理函數(shù)中使用的全局變量
在 Unix/Linux 下,信號(hào)處理函數(shù)可能異步修改某個(gè)全局變量,主程序需要檢測(cè)該變量的變化。
如果不加 volatile,編譯器可能把變量讀取優(yōu)化成一次,導(dǎo)致永遠(yuǎn)無(wú)法檢測(cè)到變化。
示例:
volatile sig_atomic_t flag = 0; <p>void signal_handler(int sig) { flag = 1; }</p><p>int main() { signal(SIGINT, signal_handler); while (!flag) { // 等待信號(hào) } return 0; }
這里用 sig_atomic_t
和 volatile 配合,確保 flag 不被優(yōu)化。
3. 多線(xiàn)程環(huán)境中(有限作用)
雖然 volatile 在某些平臺(tái)曾被用于多線(xiàn)程編程,但它不能替代原子操作或互斥鎖。volatile 不提供原子性,也不保證內(nèi)存順序。
C++11 起推薦使用 std::atomic
來(lái)處理并發(fā)共享變量。volatile 在此場(chǎng)景下容易被誤用,應(yīng)避免依賴(lài)它實(shí)現(xiàn)線(xiàn)程同步。
volatile 可以和 const 一起使用,表示“只讀但可能被外部改變”的變量。
例如:
const volatile int* reg = &device_status;
表示 reg 指向一個(gè)不能通過(guò) reg 修改(const),但可能被硬件改變(volatile)的值。
基本上就這些。volatile 的本質(zhì)是“別動(dòng)我的內(nèi)存訪(fǎng)問(wèn)”,適用于變量值可能被程序外因素修改的場(chǎng)景。正確使用它可以避免因編譯器優(yōu)化導(dǎo)致的隱蔽 bug。不過(guò)在現(xiàn)代 C++ 并發(fā)編程中,應(yīng)優(yōu)先使用原子類(lèi)型和同步機(jī)制,而非依賴(lài) volatile。
以上就是c++++中volatile關(guān)鍵字是做什么用的_c++ volatile的含義與使用場(chǎng)景的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!
c++怎么學(xué)習(xí)?c++怎么入門(mén)?c++在哪學(xué)?c++怎么學(xué)才快?不用擔(dān)心,這里為大家提供了c++速學(xué)教程(入門(mén)到精通),有需要的小伙伴保存下載就能學(xué)習(xí)啦!
微信掃碼
關(guān)注PHP中文網(wǎng)服務(wù)號(hào)
QQ掃碼
加入技術(shù)交流群
Copyright 2014-2025 http://ipnx.cn/ All Rights Reserved | php.cn | 湘ICP備2023035733號(hào)