linux下信號量和互斥鎖的區(qū)別是:1、信號量用在多線程多任務同步時,而互斥鎖是用在多線程多任務互斥的;2、信號量可以當一個線程完成了某個動作時,讓別的線程再進行某些動作,而互斥鎖線程一旦占用某個資源,別的線程就無法訪問。
本教程操作環(huán)境:linux7.3系統(tǒng)、Dell G3電腦。
linux下信號量和互斥鎖的區(qū)別是什么
信號量(semaphore[?sem?f?:(r)])用在多線程多任務同步的,一個線程完成了某一個動作就通過信號量告訴別的線程,別的線程再進行某些動作。
而互斥鎖(Mutual exclusion,縮寫 Mutex)是用在多線程多任務互斥的,一個線程占用了某一個資源,那么別的線程就無法訪問,直到這個線程unlock,其他的線程才開始可以利用這個資源。
比如對全局變量的訪問,有時要加鎖,操作完了,在解鎖。盡管兩個概念有點類似,但是他們的側重點不一樣,信號量不一定是鎖定某一個資源,而是流程上的概念,
比如:有A,B兩個線程,B線程要等A線程完成某一任務以后再進行自己下面的步驟,這個任務并不一定是鎖定某一資源,還可以是進行一些計算或者數(shù)據(jù)處理之類。
而線程互斥量則是“鎖住某一資源”的概念,在鎖定期間內,其他線程無法對被保護的數(shù)據(jù)進行操作。
不難看出,mutex是semaphore的一種特殊情況(n=1時)。
也就是說,完全可以用后者替代前者。但是,因為mutex較為簡單,且效率高,所以在必須保證資源獨占的情況下,還是采用這種設計。