您好,登錄后才能下訂單哦!
Go語言中mutex如何使用,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
臨界區(Critical Section): 當程序并發地運行時,多個Go協程不應該同時訪問那些修改共享資源的代碼,這些修改共享資源的代碼稱為臨界區。
競態條件:它旨在描述一個系統或者進程的輸出依賴于不受控制的事件出現順序或者出現時機。舉例來說,如果計算機中的兩個進程同時試圖修改一個共享內存的內容,在沒有并發控制的情況下,最后的結果依賴于兩個進程的執行順序與時機。而且如果發生了并發訪問沖突,則最后的結果是不正確的。
鎖:是在執行并發時用于強行限制資源訪問的同步機制,即用于在并發控制中保證對互斥要求的滿足。一般的鎖是建議鎖(advisory lock),每個線程在訪問對應資源前都需獲取鎖的信息,再根據信息決定是否可以訪問。若訪問對應信息,鎖的狀態會改變為鎖定,因此其他線程此時不會訪問該資源,當資源結束后,會恢復鎖的狀態,允許其他線程的訪問。
在了解了上面的基本概念之后,我們來看下Go語言中的mutex。
mutex 用于提供一種加鎖機制,可確保在某時刻只有一個協程在臨界區運行,以防止出現競態條件。
mutexs是Go的sync包中的一個數據結構,定義了兩個方法:Lock 和 Unlock。所有在 Lock 和 Unlock 之間的代碼,都只能由一個 Go 協程執行,于是就可以避免競態條件。
1) 不用mutex的例子:
output:
結果分析:我們執行了5次程序,發現輸出的結果并不一致。原因就是 這100個協程,產生了競態關系,導致計算的結果,并不是100, 而是變成了不確定的值。
2)使用mutex的例子:(我們通過mutex的鎖機制來解決這個問題)
Output:
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。