Go語(yǔ)言包中的 sync 包提供了兩種鎖類(lèi)型:sync.Mutex 和 sync.RWMutex。 (推薦學(xué)習(xí):go)
Mutex 是最簡(jiǎn)單的一種鎖類(lèi)型,同時(shí)也比較暴力,當(dāng)一個(gè) goroutine 獲得了 Mutex 后,其他 goroutine 就只能乖乖等到這個(gè) goroutine 釋放該 Mutex。
RWMutex 相對(duì)友好些,是經(jīng)典的單寫(xiě)多讀模型。在讀鎖占用的情況下,會(huì)阻止寫(xiě),但不阻止讀,也就是多個(gè) goroutine 可同時(shí)獲取讀鎖(調(diào)用 RLock() 方法;
而寫(xiě)鎖(調(diào)用 Lock() 方法)會(huì)阻止任何其他 goroutine(無(wú)論讀和寫(xiě))進(jìn)來(lái),整個(gè)鎖相當(dāng)于由該 goroutine 獨(dú)占。從 RWMutex 的實(shí)現(xiàn)看,RWMutex 類(lèi)型其實(shí)組合了 Mutex:
type RWMutex struct { w Mutex writerSem uint32 readerSem uint32 readerCount int32 readerWait int32 }
sync.mutex 加鎖后禁止其他地方讀或?qū)?,這個(gè)適用于可能出現(xiàn)的在不同go協(xié)程中修改同一個(gè)數(shù)據(jù)
sync.rwmutex 的lock 和 unlock 的使用和sync.mutex類(lèi)似
sync.rwmutex 的rlock和runlock的使用適用于要讀取數(shù)據(jù),防止在讀取的同時(shí)可能出現(xiàn)的別的地方寫(xiě)入,而導(dǎo)致的讀取失敗