go 语言提供屏障模式来协调对共享资源的访问,主要包括两种类型:互斥锁(sync.mutex):仅允许一个 goroutine 访问共享资源。读写互斥锁(sync.rwmutex):允许多个 goroutine 同时读取资源,但一次只能有一个 goroutine 写入资源。
Go 语言屏障模式
屏障模式是 Go 语言中的一种并发原语,它允许您在并发环境中协调对共享资源的访问。
主要类型
Go 语言中有两种主要的屏障模式:
- sync.Mutex: 互斥锁,一次只允许一个 goroutine 访问共享资源。
- sync.RWMutex: 读写互斥锁,允许多个 goroutine 同时读取资源,但一次只能有一个 goroutine 写入资源。
互斥锁 (sync.Mutex)
互斥锁通过 Lock() 和 Unlock() 方法实现。当一个 goroutine 获取互斥锁时,其他试图获取该互斥锁的 goroutine 将被阻塞,直到该互斥锁被释放。
var mu sync.Mutex func main() { mu.Lock() // 访问共享资源 mu.Unlock() }
读写互斥锁 (sync.RWMutex)
读写互斥锁通过 RLock() 和 RUnlock()(读取)以及 Lock() 和 Unlock()(写入)方法实现。多个 goroutine 可以同时 RLock() 共享资源,而只有一个 goroutine 可以在任何给定时间 Lock() 共享资源。
立即学习“go语言免费学习笔记(深入)”;
var rwmu sync.RWMutex func main() { rwmu.RLock() // 读取共享资源 rwmu.RUnlock() rwmu.Lock() // 写入共享资源 rwmu.Unlock() }