Mutex的count有三種可能值。“1”代表unlocked,"0"代表lokced,負值代表可能的等待者。 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會被中斷程式中斷。
Mutex的count有三種可能值。“1”代表unlocked,"0"代表lokced,負值代表可能的等待者。 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會被中斷程式中斷。