自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

C++ 里 ++i 是原子操作嗎?

開發(fā)
對于嵌入式開發(fā)等要求原子操作顯式控制的場景,C++11提供了一些新的原子類型和同步原語來保證操作的原子執(zhí)行。?

1.什么是原子操作

在多線程環(huán)境下,原子操作是指不會被線程調(diào)度機制打斷的操作;這種操作一旦開始,就一直運行到結(jié)束,中間不會有任何 context switch (切換到另一個線程)。

原子操作可以確保某些特定操作在多線程條件下,不會由于線程切換而導(dǎo)致數(shù)據(jù)污染。比如,對一個變量的讀/寫操作,就是一個常見的需要原子化的場景。如果把這樣的讀/寫操作設(shè)計成原子操作,就可以避免多線程競爭導(dǎo)致的數(shù)據(jù)不一致問題。

2.++i 是否原子操作

在 C++ 中,對一個變量的自增(++)操作看似很簡單,理論上它包含:

  • 讀變量原值
  • 對原值加 1
  • 將結(jié)果寫回變量

例如:

int i = 0; 
++i;

但是在多線程環(huán)境下,這三個步驟如果被打斷,可能導(dǎo)致如下結(jié)果:

  • 線程1 讀到i=0
  • 線程2也讀到i=0
  • 線程1對i加1并寫入,現(xiàn)在i=1
  • 線程2對i加1并寫入,這時覆蓋了線程1的寫入,又使得i=1

很明顯,實際的運行次數(shù)是2次,但最終結(jié)果是i=1,這就是數(shù)據(jù)污染的例子。

為了避免上述情況,C++編譯器在編譯過程中,會自動將一些看似簡單的操作(例如自增操作)轉(zhuǎn)換為原子指令,從而保證其原子性。

這種特性與具體的編譯器實現(xiàn)相關(guān),比如主流的GNU編譯器和MSVC編譯器都對自增操作進行了優(yōu)化,確保其原子執(zhí)行。

所以可以認為,在絕大多數(shù)C++實現(xiàn)中,++i這個自增操作是原子的。但是仍有一些例外情況需要注意,比如在嵌入式平臺上可能需要開發(fā)者顯式指定操作的原子性。

3. 如何保證操作的原子性

在不能依賴編譯器優(yōu)化的情況下,C++11提供了一些方法可以保證操作的原子性:

(1) atomic類型:提供了一些原子類型,對其操作天然原子

int i = 0; 
++i;

(2) mutex:使用mutex可以在臨界區(qū)內(nèi)執(zhí)行一個原子塊

std::mutex m;
m.lock();
// critical section
cnt++; 
m.unlock();

(3) lock-free編程:通過CAS(compare-and-swap)等原子指令實現(xiàn)非阻塞同步

atomic_int val;
int expect = val.load();
while(!val.compare_exchange_weak(expect, expect + 1)) {
  expect = val.load(); 
} atomic_int val;
int expect = val.load();
while(!val.compare_exchange_weak(expect, expect + 1)) {
  expect = val.load(); 
}

4. 總結(jié)

綜上所述,在大多數(shù)普通的桌面程序和服務(wù)端程序中,++i這樣的自增操作可以看作是原子的,編譯器會做出優(yōu)化。但是對于嵌入式開發(fā)等要求原子操作顯式控制的場景,C++11提供了一些新的原子類型和同步原語來保證操作的原子執(zhí)行。

責(zé)任編輯:趙寧寧 來源: 鯊魚編程
相關(guān)推薦

2011-07-20 14:33:19

C++IO

2014-01-09 09:45:41

原子飛原子

2022-09-09 15:32:46

intC語言原子操作

2022-07-01 11:07:56

int原子操作代碼

2011-05-24 17:20:57

程序員

2021-04-01 17:36:30

鴻蒙HarmonyOS應(yīng)用開發(fā)

2016-10-20 16:07:11

C++Modern C++異步

2023-10-04 00:38:30

C++原子

2015-09-07 13:55:53

PHPC++

2022-08-22 15:32:59

C++C代碼

2010-01-28 11:16:28

C++操作符

2024-04-07 09:59:42

C++并發(fā)編程開發(fā)

2011-06-17 16:09:04

freadfwrite

2010-01-21 10:23:53

C++代碼

2020-11-27 06:44:22

原子加鎖x86

2010-01-28 15:38:57

學(xué)習(xí)C++意義

2024-06-24 12:41:40

2023-12-13 10:08:59

C++原子代碼

2023-11-17 11:40:51

C++內(nèi)存

2010-01-21 14:28:03

C++靜態(tài)成員函數(shù)
點贊
收藏

51CTO技術(shù)棧公眾號