go中的sync包
在Go语言中,除了使用channel进行goroutine之间的通信和同步操作外,还可以使用syne包下的并发工具。
并发工具类 | 说明 |
---|---|
Mutex | 互斥锁 |
RWMutex | 读写锁 |
WaitGroup | 并发等待组 |
Map | 并发安全字典 |
Cond | 同步等待条件 |
Once | 只执行一次 |
Pool | 临时对象池 |
Mutex(互斥锁)
sync. Muer互斥锁能够保证在同一个时间段内仅有一个goroutine持有锁,这就能够保证在某一时间段内有且仅有一个goroutine访问共享资源,其他申请锁的goroutine将会被阻塞直到锁被释放,然后重新争抢锁的持有权。syne.Mutex 提供以下两个方法:
//加锁
Lock()
//释放锁
Unlock()
使用sync.Mutex控制多goroutine串行执行
执行结果
使用sync.Mutex能够保证每次只有一个goroutine访问同步代码块中的资源从而对资源进行原子操作
RWMutex(读写锁)
sync. RWMutex即我们熟知的读写锁,它将读锁和写锁的操作分离开来。为了保证在同一时间段能够有多个goroutine访问同一资源,它需要满足以下条件:
-
在同一时间段只能有一个goroutine获取到写锁。
-
在同一时间段可以有任意多个gorouinte获取到读锁。
-
在同一时间段只能存在写锁或读锁(读锁和写锁互斥)。
sync.RWMutex提供以下接口:
//写加锁
func (rw