C++ STL 基礎與多線程安全性說明文檔

C++ STL 基礎與多線程安全性說明文檔

一、STL 簡介

STL(Standard Template Library,標準模板庫)是 C++ 標準庫的重要組成部分,提供了常用的數據結構和算法的泛型實現,極大地提高了代碼的復用性和開發效率。

STL 的六大組件

  1. 容器(Containers):如 vectorlistdequesetmapunordered_map 等,用于存儲數據。
  2. 算法(Algorithms):如 sortfindfor_each 等,作用于容器。
  3. 迭代器(Iterators):提供一種統一方式遍歷容器元素,是容器與算法之間的橋梁。
  4. 函數對象(Function Objects / Functors):可作為算法的參數,具有函數調用運算符。
  5. 適配器(Adapters):對容器或函數進行包裝,如 stackqueuepriority_queuebind
  6. 分配器(Allocators):內存分配策略的封裝,一般使用默認即可。

二、STL 容器性能對比

常見 STL 容器性能分析

容器插入刪除查找隨機訪問是否排序是否允許重復
vector尾部 O(1),中間 O(n)O(n)O(n)O(1)
list任意位置 O(1)*O(1)*O(n)
deque頭尾 O(1),中間 O(n)O(n)O(n)O(1)
set / mapO(log n)(紅黑樹)O(log n)O(log n)
unordered_set / unordered_map平均 O(1),最壞 O(n)O(1)O(1)
stack / queue / priority_queueO(1) 或 O(log n)O(1) 或 O(log n)無查找N/A

注:list 的插入/刪除在給定迭代器位置下是 O(1),但查找該位置是 O(n)

推薦使用場景

場景需求推薦容器
快速插入刪除,頻繁操作兩端dequelist
快速尾部插入和隨機訪問vector
快速查找,自動排序setmap
快速查找,順序無關unordered_setunordered_map
需要先進先出 / 后進先出queuestack
需要大頂堆、小頂堆priority_queue

Demo: 查找性能對比

#include <iostream>
#include <vector>
#include <set>
#include <unordered_set>
#include <chrono>using namespace std;
using namespace std::chrono;const int N = 1e6;
int target = N - 1;int main() {vector<int> v;set<int> s;unordered_set<int> us;for (int i = 0; i < N; ++i) {v.push_back(i);s.insert(i);us.insert(i);}auto t1 = high_resolution_clock::now();auto it1 = find(v.begin(), v.end(), target);auto t2 = high_resolution_clock::now();cout << "vector find time: " << duration_cast<microseconds>(t2 - t1).count() << "us" << endl;t1 = high_resolution_clock::now();auto it2 = s.find(target);t2 = high_resolution_clock::now();cout << "set find time: " << duration_cast<microseconds>(t2 - t1).count() << "us" << endl;t1 = high_resolution_clock::now();auto it3 = us.find(target);t2 = high_resolution_clock::now();cout << "unordered_set find time: " << duration_cast<microseconds>(t2 - t1).count() << "us" << endl;return 0;
}

三、STL 容器的多線程安全性分析

STL 容器線程安全原則

  • ? 只讀共享是安全的(多個線程只讀)
  • ? 寫入操作必須加鎖保護
  • ? 多線程同時修改同一個容器是危險的

各容器線程安全性對比

容器多線程只讀多線程寫入是否自帶同步
vector? 安全? 不安全? 無同步
map / set? 安全? 不安全? 無同步
unordered_map? 安全? 不安全? 無同步
queue / stack? 一般不安全? 不安全? 無同步

常見錯誤示例

#include <vector>
#include <thread>std::vector<int> v;void writer() {for (int i = 0; i < 10000; ++i) {v.push_back(i);  // ? 非線程安全}
}int main() {std::thread t1(writer);std::thread t2(writer);t1.join();t2.join();return 0;
}

正確寫法:加鎖保護

#include <vector>
#include <mutex>
#include <thread>std::vector<int> v;
std::mutex mtx;void safe_writer() {for (int i = 0; i < 10000; ++i) {std::lock_guard<std::mutex> lock(mtx);v.push_back(i);}
}

替代方案與推薦庫

目標替代建議
并發隊列boost::lockfree::queue、TBB、Folly、MoodyCamel
并發哈希表tbb::concurrent_hash_maplibcds
自定義多線程容器封裝封裝 std::mutex 或使用 shared_mutex

四、最佳實踐

  • 所有寫操作務必加鎖,或使用原子容器
  • 避免在遍歷期間修改容器
  • 如果性能要求高,考慮使用專用并發容器庫
  • 使用 condition_variable + mutex 實現生產者消費者模型

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/79972.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/79972.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/79972.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

數據結構之圖的分類和存儲

圖 圖(Graph)G由兩個集合V和E組成&#xff0c;記為&#xff1a;G(V,E)&#xff0c;其中V是頂點的有窮非空集合(其實就是頂點)&#xff0c;E是V 中頂點偶對的有窮集合(就是邊)。V(G)和E(G)通常分別表示圖G的頂點集合以及邊集合&#xff0c;E(G)可以為空集合&#xff0c;但是此時…

擴增子分析|微生物生態網絡穩定性評估之魯棒性(Robustness)和易損性(Vulnerability)在R中實現

一、引言 周集中老師團隊于2021年在Nature climate change發表的文章&#xff0c;闡述了網絡穩定性評估的原理算法&#xff0c;并提供了完整的代碼。自此對微生物生態網絡的評估具有更全面的指標&#xff0c;自此網絡穩定性的評估廣受大家歡迎。本系列將介紹網絡穩定性之魯棒性…

setup 函數在 Vue 3 中的作用是什么?什么時候會執行

文章目錄 前言? 一、setup() 函數的作用是什么&#xff1f;? 二、setup() 什么時候執行&#xff1f;? 三、setup() 的參數? 四、setup() 中不能做什么&#xff1f;? 五、常見用法示例? 六、總結&#xff08;適合背誦或面試回答&#xff09; <script setup> 是 **Vu…

JDBC實現--保姆級教程~

本來以為寫過一個使用python與數據庫連接的文章&#xff0c;但是今天突然發現沒有&#xff0c;那就直接寫Java與數據庫連接的吧。當然如果大家有需要可以告訴我&#xff0c;有時間的話也可以寫一個的pymysql的使用的。 數據庫有很多種&#xff0c;接下來我就以MySQL為例來進行講…

Ubuntu18.04搭建samda服務器

一.什么是Samba服務器&#xff1f; Samba服務器是一種基于開源協議實現的網絡共享服務軟件&#xff0c;主要用于在不同操作系統&#xff08;如Windows、Linux、Unix&#xff09;之間實現文件和打印機共享功能。其核心目標是解決跨平臺資源共享的兼容性問題&#xff0c;尤其是在…

《分詞算法大揭秘:BPE、BBPE、WordPiece、ULM常見方法介紹》

分詞算法是自然語言處理&#xff08;NLP&#xff09;中的一個重要預處理步驟&#xff0c;它將文本分割成更小的單元&#xff08;如單詞、子詞或字符&#xff09;。以下是幾種常見的分詞算法&#xff1a;Byte Pair Encoding (BPE)、Byte-level BPE (BBPE)、WordPiece 和 Unigram…

WordPress01 - 后臺常用功能

最近些日子研究Wordpress&#xff0c;做些簡單的筆記。 怎么安裝Wordpress&#xff0c;怎么進的后臺&#xff0c;這些咱就不嘮了哈&#xff0c;網上到處是教程。 目錄 1&#xff0c;Wordpress的后臺 1-1&#xff0c; Posts(投稿) 1-2&#xff0c;Media(媒體) 1-3&#xf…

R8周:RNN實現阿爾茨海默病診斷

&#x1f368; 本文為&#x1f517;365天深度學習訓練營中的學習記錄博客 &#x1f356; 原作者&#xff1a;K同學啊 一、前期準備 1.設置GPU import numpy as np import pandas as pd import torch from torch import nn import torch.nn as nn import torch.nn.functi…

今天python練習題

目錄 一、每日一言 二、練習題 三、效果展示 四、下次題目 五、總結 一、每日一言 不要害怕失敗&#xff0c;失敗可能成為我們前進的動力&#xff01; 二、練習題 有列表lst [[1,2,3],[4,5,6],[7,8,9]],取出其中的元素1/5/9組成新的列表 # 有列表lst [[1,2,3],[4,5,6],[…

機器人強化學習入門學習筆記(二)

基于上一篇的《機器人強化學習入門學習筆記》,在基于 MuJoCo 的仿真強化學習訓練中,除了 PPO(Proximal Policy Optimization)之外,還有多個主流強化學習算法可用于訓練機器人直行或其他復雜動作。 ?? 一、常見強化學習算法對比(可用于 MuJoCo) 算法類型特點適合場景PP…

用 DuckDB 高效分析 JSON 數據:從入門到實戰

解析 JSON 文件進行分析常常充滿挑戰。無論你是在處理 API 響應、日志文件&#xff0c;還是應用數據&#xff0c;如果沒有合適的工具&#xff0c;分析 JSON 都會非常耗時。 借助 DuckDB&#xff0c;你可以直接用 SQL 查詢復雜的 JSON 文件&#xff0c;無需編寫復雜的解析代碼或…

從貼牌到品牌:出海官網如何讓中國制造“貴”起來?

在全球經濟一體化的當下&#xff0c;中美關稅戰如同一記重錘&#xff0c;給國際貿易格局帶來了巨大震蕩。自貿易摩擦爆發以來&#xff0c;雙方多次調整關稅政策&#xff0c;涉及的商品種類不斷增多&#xff0c;稅率持續攀升&#xff0c;眾多中國企業的出口業務遭受重創&#xf…

react-13react中外部css引入以及style內聯樣式(動態className與動態style)

1. 外部css文件 - 普通引入 1.1 創建一個 CSS 文件&#xff0c;MyComponent.css。 /* MyComponent.css */ .my-class {color: red;font-size: 20px; } 1.2 組件中import引入 import React from react; import ./MyComponent.css; // 引入 CSS 文件function MyComponent() {r…

n8n 與智能體構建:開發自動化 AI 作業的基礎平臺

n8n 是一款開源的自動化流程構建平臺&#xff0c;通過其模塊化節點系統&#xff0c;開發者可以快速實現跨平臺的任務編排、數據集成與智能交互。當 n8n 與大型語言模型&#xff08;LLM&#xff09;結合時&#xff0c;就能構建出具備感知、推理、執行能力的 AI 智能體&#xff0…

14.Spring Boot 3.1.5 集成 Spring Security 進行訪問控制

14.Spring Boot 3.1.5 集成 Spring Security 進行訪問控制 Spring Security 是一個強大且高度可定制的認證和訪問控制框架&#xff0c;專為基于 Spring 的應用程序設計。它為基于 Java EE 的企業應用程序提供了全面的安全解決方案&#xff0c;包括 Web 應用程序安全和方法級安…

Linux學習筆記(二):Linux權限管理

文章目錄 一、Linux下用戶的分類1. Linux下用戶分為兩類&#xff1a;2. 這兩類用戶如何進行切換呢&#xff1f;3. 短暫提權 二、何為權限1. 什么是權限2. Linux的文件后綴意義 三、修改權限1. 設置文件的訪問權限——chmod2. 修改文件擁有者——chown3. 修改文件所屬組——chgr…

學習alpha,第2個alpha

alphas (-1 * ts_corr(rank(ts_delta(log(volume), 2)), rank(((close - open) / open)), 6)) 先分析操作符從左到右 ts_corr: Pearson 相關度量兩個變量之間的線性關系。當變量呈正態分布且關系呈線性時&#xff0c;它最有效。 ts_corr(vwap, close, 20)是一個計算時間序列相…

Paddle Serving|部署一個自己的OCR識別服務器

前言 之前使用C部署了自己的OCR識別服務器&#xff0c;Socket網絡傳輸部分是自己寫的&#xff0c;回過頭來一看&#xff0c;自己犯傻了&#xff0c;PaddleOCR本來就有自己的OCR服務器項目&#xff0c;叫PaddleServing&#xff0c;這里記錄一下部署過程。 1 下載依賴環境 1.1 …

React Native【詳解】搭建開發環境,創建項目,啟動項目

下載安裝 node https://nodejs.cn/download/ 查看 npx 版本 npx -v若無 npx 則安裝 npm install -g npx創建項目 npx create-expo-applatestRN_demo 為自定義的項目名稱 下載安裝 Python 2.7 下載安裝 JAVA JDK https://www.oracle.com/java/technologies/downloads/#jdk24-…

NVIDIA Halos:智能汽車革命中的全棧式安全系統

高級輔助駕駛行業正面臨一個尷尬的"安全悖論"——傳感器數量翻倍的同時&#xff0c;事故率曲線卻遲遲不見明顯下降。究其原因&#xff0c;當前行業普遍存在三大技術困局&#xff1a; 碎片化安全方案 傳統方案就像"打補丁"&#xff0c;激光雷達廠商只管點云…