UNIX(多线程):27---多线程并发之原子操作与无锁编程
生活随笔
收集整理的這篇文章主要介紹了
UNIX(多线程):27---多线程并发之原子操作与无锁编程
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
原子操作:顧名思義就是不可分割的操作,該操作只存在未開始和已完成兩種狀態(tài),不存在中間狀態(tài);
原子類型:原子庫中定義的數(shù)據(jù)類型,對這些類型的所有操作都是原子的,包括通過原子類模板std::atomic< T >實(shí)例化的數(shù)據(jù)類型,也都是支持原子操作的。
二、如何使用原子類型
2.1 原子庫atomic支持的原子操作
原子庫< atomic >中提供了一些基本原子類型,也可以通過原子類模板實(shí)例化一個(gè)原子對象,下面列出一些基本原子類型及相應(yīng)的特化模板如下:
對原子類型的訪問,最主要的就是讀和寫,但原子庫提供的對應(yīng)原子操作是load()與store(val)。
2.2 原子操作中的內(nèi)存訪問模型
原子操作保證了對數(shù)據(jù)的訪問只有未開始和已完成兩種狀態(tài),不會訪問到中間狀態(tài),但我們訪問數(shù)據(jù)一般是需要特定順序的,比如想讀取寫入后的最新數(shù)據(jù),原子操作函數(shù)是支持控制讀寫順序的,即帶有一個(gè)數(shù)據(jù)同步內(nèi)存模型參數(shù)std::memory_order,用于對同一時(shí)間的讀寫操作進(jìn)行排序。C++11定義的6種類型如下:
總結(jié)
以上是生活随笔為你收集整理的UNIX(多线程):27---多线程并发之原子操作与无锁编程的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 数据结构课上笔记15
- 下一篇: insert函数的修改,