當前位置:編程學習大全網 - 網站源碼 - linux中mutex和semaphore的區別

linux中mutex和semaphore的區別

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會被中斷程序中斷。

  • 上一篇:聊城大學的小白什麽時候是最後壹個?
  • 下一篇:mintui裏action sheet怎麽使用回調函數
  • copyright 2024編程學習大全網