一文帶你讀懂C++memory_order?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
創(chuàng)新互聯(lián)公司主要從事做網(wǎng)站、成都做網(wǎng)站、網(wǎng)頁設計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務。立足成都服務順平,10年網(wǎng)站建設經(jīng)驗,價格優(yōu)惠、服務專業(yè),歡迎來電咨詢建站服務:028-86922220看了c++并發(fā)編程實戰(zhàn)的內(nèi)存模型部分后,一直對memory_order不太懂,今天在知乎發(fā)現(xiàn)了百度的brpc,恰好有關于原子操作的文檔,感覺解釋的很好。為了加深理解,再次總結一遍。
在多核編程中,我們使用鎖來避免多個線程修改同一個數(shù)據(jù)時產(chǎn)生的競爭條件。但是,鎖會消耗系統(tǒng)資源,當鎖成為性能瓶頸的時候,就需要使用另一種方法——原子指令。c++11中引入了原子類型atomic。
原子指令 (x均為std::atomic)作用x.load()返回x的值。x.store(n)把x設為n,什么都不返回。x.exchange(n)把x設為n,返回設定之前的值。x.compare_exchange_strong(expected_ref, desired)若x等于expected_ref,則設為desired,返回成功;否則把最新值寫入expected_ref,返回失敗。x.compare_exchange_weak(expected_ref, desired)相比compare_exchange_strong可能有spurious wakeup。x.fetch_add(n), x.fetch_sub(n)原子地做x += n, x-= n,返回修改之前的值。
但僅靠原子指令實現(xiàn)不了對資源的訪問控制。這造成的原因是編譯器和cpu實施了重排指令,導致讀寫順序會發(fā)生變化,只要不存在依賴,代碼中后面的指令可能會被放在前面,從而先執(zhí)行它。cpu這么做是為了盡量塞滿每個時鐘周期,在單位時間內(nèi)盡量執(zhí)行更多的指令,從而提高吞吐率。
下面看個例子:
// thread 1 // ready was initialized to false p.init(); ready = true;
網(wǎng)頁名稱:一文帶你讀懂C++memory_order-創(chuàng)新互聯(lián)
文章地址:http://aaarwkj.com/article8/codjop.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供響應式網(wǎng)站、手機網(wǎng)站建設、網(wǎng)站收錄、ChatGPT、電子商務、面包屑導航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)