c++11 原子類型與原子操做

一、原子類型和原子操做
(1)類型
c++11 原子類型與原子操做
(2)操做
c++11 原子類型與原子操做
(3)詳述
● 原子類型只能從其模板參數類型中進行構造,標準不容許原子類型進行拷貝構造、移動構造,以及使用operator=等
● atomic_flag 是一個原子的布爾類型,無鎖的,即線程對其訪問不須要加鎖;可支持test_and_set()是一種原子操做,用於在一個內存空間原子地寫入新值而且返回舊值,若是對象被設置了,則返回true;clear()清除對象值,將變量值設爲false;
二、內存模型,順序一致性和memory_order
(1)類型
c++11 原子類型與原子操做
(2)詳述
● x86以及SPARC(TSO模式)都被看做是採用強順序內存模型的平臺;而Alpha、PowerPC、ArmV7等平臺,則採用弱順序內存模型
● 存在弱順序的內存模型緣由:可以使得處理器進一步發掘指令中的並行性,使得指令執行的性能更高
● 默認狀況下,原子類型的變量在線程中老是保持着順序執行的特性。
● 原子存儲操做store可以使用relaxed seq_cst release;原子寫操做load可以使用relaxed seq_cst acquire consume;可讀可寫操做可以使用全部
● 先於發生關係老是傳遞的
三、線程局部存儲
(1)擁有線程生命週期及線程可見性的變量
(2)如POSIX標準中的錯誤碼全局變量errno,在多線程中將遭遇問題;
(3)c++11中的解決方法是經過thread_local 修飾符聲明變量便可:如int thread_local errCode;則errCode在線程開始時被初始化,而在線程結束時該值不在有效
四、快速退出
(1)teminate函數;沒有被捕捉的異常就會致使其被調用,其默認是去調用abort函數。可經過set_terminate函數改變默認行爲
(2)abort不會調用任何析構函數<terminate默認下也同樣>,拋出信號:SIGABRT
(3)exit:屬於正常退出範疇的程序終止,會正常調用自動變量的析構函數,且會調用atexit註冊的函數,調用次序與其註冊順序相反
(4)在C++11中,引入quick_exit,該函數並不執行析構函數而只是使程序終止。與abort不一樣,abort是異常退出,quick_exit和exit同屬於正常退出。也可以使用at_quick_exit註冊函數c++

相關文章
相關標籤/搜索