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