線程安全是編程中的術語,指某個函數、函數庫在多線程環境中被調用時,能夠正確地處理多個線程之間的共享變量,使程序功能正確完成。
<br>
一般來說,線程安全的函數應該為每個調用它的線程分配專門的空間,來儲存需要單獨保存的狀態(如果需要的話),不依賴于“線程慣性”,把多個線程共享的變量正確對待(如,通知編譯器該變量為“易失(volatile)”型,阻止其進行一些不恰當的優化),而且,線程安全的函數一般不應該修改全局對象。
<br>
很多C庫代碼(比如某些strtok的實現,它將“多次調用中需要保持不變的狀態”儲存在靜態變量中,導致不恰當的共享)不是線程安全的,在多線程環境中調用這些函數時,要進行特別的預防措施,或者尋找別的替代方案。
<br>
## 產生線程不安全的原因
在同一程序中運行多個線程本身不會導致問題,問題在于多個線程訪問了相同的資源。如,同一內存區(變量,數組,或對象)、系統(數據庫,web services等)或文件。實際上,這些問題只有在一或多個線程向這些資源做了寫操作時才有可能發生,只要資源沒有發生變化,多個線程讀取相同的資源就是安全的。
- 概述說明
- 數據結構
- 數組
- 棧
- 隊列
- 鏈表
- 樹
- 堆
- 圖
- 常用算法
- 排序算法
- 選擇排序
- 冒泡排序
- 插入排序
- 快速排序
- 歸并排序
- 希爾排序
- 堆排序
- 計數排序
- 基數排序
- 二分查找
- 貪心算法
- 回溯算法
- 剪枝算法
- 分支限界法
- 動態規劃
- 設計模式
- 工廠模式
- 抽象工廠模式
- 單例模式
- 建造者模式
- 原型模式
- 適配器模式
- 橋接模式
- 過濾器模式
- 組合模式
- 裝飾器模式
- 外觀模式
- 享元模式
- 代理模式
- 責任鏈模式
- 命令模式
- 解釋器模式
- 迭代器模式
- 中介者模式
- 備忘錄模式
- 觀察者模式
- 狀態模式
- 空對象模式
- 策略模式
- 模板模式
- 訪問者模式
- 并發
- 多線程
- 線程安全
- 一致性、事務
- 鎖
- 操作系統
- 計算機原理
- CPU
- 進程
- 線程
- 協程
- Linux
- 運維
- 常規監控
- 統計分析
- 自動化運維
- 測試
- 文檔管理
- 日志管理
- 中間件
- Web Server
- Nginx
- Apache
- Tomcat
- 緩存
- 消息隊列
- 網絡協議
- 協議
- OSI 七層協議
- TCP/IP
- HTTP
- HTTP2.0
- HTTPS
- 網絡模型
- Epoll
- kqueue
- 數據庫
- 基礎理論
- MySQL
- NoSQL
- 搜索引擎
- Elasticsearch
- sphinx
- Lucene
- 性能
- 性能優化方法論
- 容量評估
- CDN 網絡
- 連接池
- 性能調優
- 安全
- web 安全
- XSS
- CSRF
- SQL 注入
- 腳本注入
- 漏洞掃描工具
- 驗證碼
- DDoS 防范
- 用戶隱私信息保護
- 加密解密
- 對稱加密
- 哈希算法
- 非對稱加密
- 服務器安全
- 數據安全
- 網絡隔離
- 授權、認證
- RBAC
- OAuth2.0
- 單點登錄(SSO)
- JWT
- 開源框架
- 開源協議
- 日志框架
- ORM
- PHP開源框架
- 分布式集群
- 擴展性設計
- 穩定性高可用
- 數據庫擴展
- 分布式一致
- 分布式文件系統
- 開發模式
- DDD(Domain-driven Design - 領域驅動設計)
- Actor 模式
- 響應式編程
- DODAF2.0
- Serverless
- Service Mesh
- 項目管理
- 架構評審
- 重構
- 代碼規范
- 代碼 Review
- 看板管理
- 敏捷開發
- 極限編程
- PDCA 循環質量管理
- FMEA管理模式
- 資訊
- 行業資訊
- 公眾號列表
- 博客
- 綜合門戶、社區
- 技術資源
- 開源資源
- 手冊、文檔、教程
- 在線課堂
- 代碼托管
- 云服務商