亚洲最大看欧美片,亚洲图揄拍自拍另类图片,欧美精品v国产精品v呦,日本在线精品视频免费

  • 站長資訊網
    最全最豐富的資訊網站

    linux下信號量和互斥鎖的區(qū)別是什么

    linux下信號量和互斥鎖的區(qū)別是:1、信號量用在多線程多任務同步時,而互斥鎖是用在多線程多任務互斥的;2、信號量可以當一個線程完成了某個動作時,讓別的線程再進行某些動作,而互斥鎖線程一旦占用某個資源,別的線程就無法訪問。

    linux下信號量和互斥鎖的區(qū)別是什么

    本教程操作環(huán)境:linux7.3系統、Dell G3電腦。

    linux下信號量和互斥鎖的區(qū)別是什么

    信號量(semaphore[?sem?f?:(r)])用在多線程多任務同步的,一個線程完成了某一個動作就通過信號量告訴別的線程,別的線程再進行某些動作。

    而互斥鎖(Mutual exclusion,縮寫 Mutex)是用在多線程多任務互斥的,一個線程占用了某一個資源,那么別的線程就無法訪問,直到這個線程unlock,其他的線程才開始可以利用這個資源。

    比如對全局變量的訪問,有時要加鎖,操作完了,在解鎖。盡管兩個概念有點類似,但是他們的側重點不一樣,信號量不一定是鎖定某一個資源,而是流程上的概念,

    比如:有A,B兩個線程,B線程要等A線程完成某一任務以后再進行自己下面的步驟,這個任務并不一定是鎖定某一資源,還可以是進行一些計算或者數據處理之類。

    而線程互斥量則是“鎖住某一資源”的概念,在鎖定期間內,其他線程無法對被保護的數據進行操作。

    不難看出,mutex是semaphore的一種特殊情況(n=1時)。

    也就是說,完全可以用后者替代前者。但是,因為mutex較為簡單,且效率高,所以在必須保證資源獨占的情況下,還是采用這種設計。

    贊(0)
    分享到: 更多 (0)
    網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號