多執行緒同步的原理
多程式多執行緒基本介紹參考
多執行緒執行
執行緒之間以併發(注意不是並行,並行是互相毫不相干的各自同時執行)方式執行。但是由於多執行緒往往擁有共同的臨界資源,比如印表機,全域性變數,控制檯等。這種資源一次只允許一個執行緒訪問和使用(互斥)。使得多執行緒必須要按照一定的次序序列執行(同步)共享資源。
在各個執行緒中使用、操作共享資源的程式碼段叫臨界區。
訊號量
訊號量是一種資料結構
一般由兩個成員組成:數值、指標
一般來說,訊號量的值代表著當前資源的使用情況
訊號量的值只能由P、V操作來改變
不同的訊號量可以實現不同場景下的執行緒同步,但是都是由P、V操作來實現。
P、V操作
P、V操作都是原子操作
P申請一個單位資源,申請不到就等待
V釋放一個單位資源,如果有等待執行緒就喚醒
P操作
P(S)
--S
如果S<0,等待
如果S>=0,繼續
V操作
V(S)
++S
如果S>0,繼續
如果S<=0,喚醒
根據P、V操作中使用的變數個數和大小,可以實現多種執行緒同步的場景:互斥體、訊號量、讀寫鎖等。這些同步工具都有類似的介面,如獲取(acquire)、釋放(release)等。
用P、V操作實現互斥
互斥訊號量mutex=1實現互斥使用印表機
用P、V操作實現簡單同步
多訊號量實現生產者和消費者(單緩衝區同步)
相關文章
- 多執行緒和多執行緒同步執行緒
- 多執行緒同步執行緒
- java 多執行緒 –同步Java執行緒
- java 多執行緒 --同步Java執行緒
- Java 執行緒同步原理探析Java執行緒
- 多執行緒同步的開發執行緒
- java多執行緒原理Java執行緒
- 多執行緒下的程式同步(執行緒同步問題總結篇)執行緒
- 【多執行緒總結(二)-執行緒安全與執行緒同步】執行緒
- 4、Linux多執行緒,執行緒同步(2)Linux執行緒
- 多執行緒(2)-執行緒同步互斥鎖Mutex執行緒Mutex
- java多執行緒–同步鎖Java執行緒
- 多執行緒 -- 同步器執行緒
- windows多執行緒同步--事件Windows執行緒事件
- 非同步VS多執行緒非同步執行緒
- 多執行緒Demo學習(執行緒的同步,簡單的執行緒通訊)執行緒
- 非同步/同步,阻塞/非阻塞,單執行緒/多執行緒概念梳理非同步執行緒
- 多執行緒的同步和非同步學習執行緒非同步
- C#多執行緒開發-執行緒同步 02C#執行緒
- #大學#Java多執行緒學習02(執行緒同步)Java執行緒
- 多執行緒(2)-執行緒同步條件變數執行緒變數
- JVM 進行執行緒同步背後的原理JVM執行緒
- 【多執行緒】ThreadLocal原理執行緒thread
- 多執行緒:原理分析整理執行緒
- 多執行緒原理實現執行緒
- Java多執行緒學習(3)執行緒同步與執行緒通訊Java執行緒
- Dart 非同步與多執行緒Dart非同步執行緒
- windows多執行緒同步--互斥量Windows執行緒
- 多執行緒靜態方法同步執行緒
- java多執行緒:執行緒池原理、阻塞佇列Java執行緒佇列
- Java多執行緒—執行緒同步(單訊號量互斥)Java執行緒
- JAVA多執行緒詳解(3)執行緒同步和鎖Java執行緒
- Java多執行緒之執行緒同步【synchronized、Lock、volatitle】Java執行緒synchronized
- iOS多執行緒程式設計:執行緒同步總結iOS執行緒程式設計
- .NET多執行緒程式設計(3):執行緒同步 (轉)執行緒程式設計
- 多執行緒下的下載原理執行緒
- Java 多執行緒同步的五種方法Java執行緒
- 那些年搞不懂的多執行緒、同步非同步及阻塞和非阻塞(一)---多執行緒簡介執行緒非同步