扩展内容(线程的同步方法)
生活随笔
收集整理的這篇文章主要介紹了
扩展内容(线程的同步方法)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1、 臨界區(CCriticalSection)
當多個線程訪問一個獨占性共享資源時,可以使用臨界區對象。擁有臨界區的線程可以訪問被保護起來的資源或代碼段,其他線程若想訪問,則被掛起,直到擁有臨界區的線程放棄臨界區為止。
2、事件(CEvent)
事件機制,分為自動重置事件對象和人工重置事件對象;
- 自動重置事件對象,一旦被觸發(有信號,setEvent(h)),那么等待的所有線程中將只有一個線程能獲得事件對象的句柄h,并同時自動的將此事件對象設置為無信號的,只有當這個線程執行完了,并且調用了setEvent(h)來觸發這個事件對象,那么其他的線程才獲得,總之每次只能有一個等待的線程獲得事件對象,因為只要其中一個線程獲得了此事件對象h,那么就會自動的將h設置成為無信號的狀態,直到調用setEvent(h)來觸發這個事件對象;它能夠確保一個線程獨占對一個資源的訪問。
- 人工重置事件對象,一旦被觸發(有信號,setEvent(h)),那么等待此事件對象的所有線程都將變成可調度的狀態,CUP會隨機的分配CPU時間給等待的所有線程,這些線程將同步的、隨機的獲取CPU的時間,來執行線程中的代碼。
3、互斥量(CMutex)
互斥量對象(包含一個線程ID,能夠知道是哪個線程訪問了他)能夠確保一個線程獨占對一個資源的訪問。
1)如果線程ID為0(無效線程ID),那么互斥量將不為任何線程所占有,他處于觸發狀態;
2)如果線程ID為非零,那么有一個線程已經占用了這個互斥量,它處于未觸發的狀態;
假設線程視圖等待一個未觸發的互斥量對象,在這種情況下,線程通常會進入等待狀態,但是,系統會檢查想要獲得互斥量的線程的線程ID與互斥量對象內部記錄的線程ID是否相同,如果相同,那么系統會讓線程保持可調度狀態,即使該互斥量尚未觸發。
互斥量與臨界區的行為完全相同,但是區別如下:互斥量是內核對象,臨界區是用戶模式下的同步對象,執行速度快于內核對象。
4、信號量(CSemphore)
信號量與其他所有內核對象相同,但是另外又包含了兩個32位的值:
一個是最大資源計數,一個是當前資源計數。
信號量的規則如下:
總結
以上是生活随笔為你收集整理的扩展内容(线程的同步方法)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 操作系统 概述
- 下一篇: 扩展内容(进程的通信方式)