資料介紹
軟件簡(jiǎn)介
SPSCQueue 是用 C++ 11 編寫(xiě)的單個(gè)生產(chǎn)者單一消費(fèi)者等待和無(wú)鎖定大小隊(duì)列。
示例代碼
SPSCQueueq(2); auto t = std::thread([&] { while (!q.front()); std::cout << *q.front() << std::endl; q.pop(); }); q.push(1); t.join();
使用
-
SPSCQueue
(size_t capacity); Create a?
SPSCqueue
?holding items of type?T
?with capacity?capacity
. Capacity need to be greater than 2. -
void emplace(Args &&... args);
Enqueue an item using inplace construction. Blocks if queue is full.
-
bool try_emplace(Args &&... args);
Try to enqueue an item using inplace construction. Returns?
true
?on success and?false
?if queue is full. -
void push(const T &v);
Enqueue an item using copy construction. Blocks if queue is full.
-
template
void push(P &&v); Enqueue an item using move construction. Participates in overload resolution only if?
std::is_constructible
. Blocks if queue is full.::value == true -
bool try_push(const T &v);
Try to enqueue an item using copy construction. Returns?
true
?on success and?false
?if queue is full. -
template
void try_push(P &&v); Try to enqueue an item using move construction. Returns?
true
?on success and?false
?if queue is full. Participates in overload resolution only if?std::is_constructible
.::value == true -
T *front();
Return pointer to front of queue. Returns?
nullptr
?if queue is empty. -
pop();
Dequeue first elment of queue. Invalid to call if queue is empty. Requires?
std::is_nothrow_destructible
.::value == true
一旦一個(gè)單一的寫(xiě)線(xiàn)程可以執(zhí)行入隊(duì)列的操作時(shí),只有一個(gè)單一的讀線(xiàn)程可以執(zhí)行取隊(duì)列操作,其他的使用都是不允許的。
實(shí)現(xiàn)原理
底層實(shí)現(xiàn)是一個(gè)環(huán)形緩沖區(qū)。
參考資料:
- Intel.?Avoiding and Identifying False Sharing Among Threads.
- Wikipedia.?Ring buffer.
- Wikipedia.?False sharing.
性能測(cè)試
以下測(cè)試結(jié)果是基于?2 socket machine with 2 x Intel(R) Xeon(R) CPU E5-2620 0 @ 2.00GHz.
NUMA Node / Core / Hyper-Thread | Throughput (ops/ms) | Latency RTT (ns) |
---|---|---|
#0,#0,#0 & #0,#0,#1 | 63942 | 60 |
#0,#0,#0 & #0,#1,#0 | 37739 | 238 |
#0,#0,#0 & #1,#0,#0 |
- 龍芯3A5000下實(shí)現(xiàn)按鍵檢測(cè)大小寫(xiě)鎖定鍵和數(shù)字鍵 0次下載
- 《2022年全球消費(fèi)者洞察調(diào)研》中國(guó)報(bào)告
- 用默認(rèn)密碼當(dāng)心變?nèi)怆u!13條消費(fèi)者物聯(lián)網(wǎng)設(shè)備必須遵循的安全實(shí)務(wù)準(zhǔn)則
- 隊(duì)列實(shí)現(xiàn)數(shù)據(jù)循環(huán)外顯示源碼下載 4次下載
- 一個(gè)小隊(duì)列,MCU專(zhuān)用
- 單一參數(shù)交流電路的分析計(jì)算
- 消費(fèi)者技術(shù)協(xié)會(huì)國(guó)際標(biāo)準(zhǔn)CTA-861-F 1次下載
- 怎么樣實(shí)現(xiàn)車(chē)輛隊(duì)列行駛系統(tǒng)的總體設(shè)計(jì)論文 5次下載
- 單片機(jī)實(shí)現(xiàn)FIFO循環(huán)隊(duì)列的代碼和資料免費(fèi)下載
- 消費(fèi)者風(fēng)險(xiǎn)態(tài)度的主觀(guān)信任模型 0次下載
- 基于多Agent的消費(fèi)者需求代理系統(tǒng)分析 41次下載
- 從消費(fèi)者角度分析數(shù)字電視的營(yíng)銷(xiāo)策略 19次下載
- 面向消費(fèi)者的NGN
- 主動(dòng)隊(duì)列管理建模及最優(yōu)控制策略
- 一種高效的磁盤(pán)隊(duì)列I/O機(jī)制
- 聊一聊消息隊(duì)列技術(shù)選型的7種消息場(chǎng)景 1125次閱讀
- 消息隊(duì)列的發(fā)展歷史 844次閱讀
- 怎么設(shè)計(jì)實(shí)現(xiàn)一個(gè)無(wú)鎖高并發(fā)的環(huán)形連續(xù)內(nèi)存緩沖隊(duì)列 1107次閱讀
- 如何使用消息隊(duì)列進(jìn)行通信 1193次閱讀
- 什么是消息隊(duì)列?消息隊(duì)列中間件重要嗎? 1263次閱讀
- SystemVerilog中的隊(duì)列 3681次閱讀
- 實(shí)現(xiàn)一個(gè)雙端隊(duì)列的步驟簡(jiǎn)析 1312次閱讀
- 關(guān)于CAS等原子操作介紹 無(wú)鎖隊(duì)列的鏈表實(shí)現(xiàn)方法 3199次閱讀
- 干貨:Linux內(nèi)核中等待隊(duì)列的四個(gè)用法 2765次閱讀
- 智能門(mén)鎖行業(yè)應(yīng)是什么樣子?從消費(fèi)者方面著手 1617次閱讀
- 消費(fèi)者對(duì)需求的日益增長(zhǎng)牽引著汽車(chē)電子的增長(zhǎng) 860次閱讀
- 智能家居系統(tǒng)具有哪些優(yōu)勢(shì),受到眾多消費(fèi)者的青睞 916次閱讀
- 淺析HMB技術(shù)給我們消費(fèi)者帶來(lái)的福音 1.7w次閱讀
- 如何提高消費(fèi)者對(duì)物聯(lián)網(wǎng)服務(wù)的信心和使用意愿方面行之有效的見(jiàn)解 2787次閱讀
- 互聯(lián)網(wǎng)+家居模式存硬傷 消費(fèi)者陷入選擇困境 737次閱讀
下載排行
本周
- 1山景DSP芯片AP8248A2數(shù)據(jù)手冊(cè)
- 1.06 MB | 532次下載 | 免費(fèi)
- 2RK3399完整板原理圖(支持平板,盒子VR)
- 3.28 MB | 339次下載 | 免費(fèi)
- 3TC358743XBG評(píng)估板參考手冊(cè)
- 1.36 MB | 330次下載 | 免費(fèi)
- 4DFM軟件使用教程
- 0.84 MB | 295次下載 | 免費(fèi)
- 5元宇宙深度解析—未來(lái)的未來(lái)-風(fēng)口還是泡沫
- 6.40 MB | 227次下載 | 免費(fèi)
- 6迪文DGUS開(kāi)發(fā)指南
- 31.67 MB | 194次下載 | 免費(fèi)
- 7元宇宙底層硬件系列報(bào)告
- 13.42 MB | 182次下載 | 免費(fèi)
- 8FP5207XR-G1中文應(yīng)用手冊(cè)
- 1.09 MB | 178次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33566次下載 | 免費(fèi)
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費(fèi)
- 4開(kāi)關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21549次下載 | 免費(fèi)
- 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書(shū))
- 0.00 MB | 15349次下載 | 免費(fèi)
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費(fèi)
- 7電子制作實(shí)例集錦 下載
- 未知 | 8113次下載 | 免費(fèi)
- 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德?tīng)栔?/a>
- 0.00 MB | 6656次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537798次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420027次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191187次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183279次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138040次下載 | 免費(fèi)
評(píng)論
查看更多