Mutex有如下約定:
有且只有壹個進程來持有。
有且只有owner本身可以unlock mutex(owner指針的作用)。
不允許遞歸鎖。但是semaphore是允許的,MySQL在這塊上,之前還有壹個BUG:Bug #24745 InnoDB semaphore wait timeout/crash – deadlock waiting for itself
只能能過API來初始化,不允許通過memset和copying來初始化。
當持有mutex時,進程壹般不退出;存放mutex的內存不能被釋放。
通常不用於軟硬件的中斷。
五、總結
從上面的定義,可以看出,semaphore壹般只是表示資源有多少,信息量有多少,用來類似於解決producer-consumer的問題和同步信號發送等。不能解決串行化問題。
而Mutex則是來解決互斥問題,保證某個資源或者代碼片段的串行訪問;因為只有owner才能釋放鎖。另外,有同學可能會問,Binary
semaphore也只有兩種可能值,也可以實現互斥訪問。但是要知道,Binary
semaphore還是沒有owner指針。但有壹點相似處,就是在ISR(Interrupt Service
Routine)系統中,semaphore或者mutex會被中斷程序中斷。