Go-竞态条件-锁

1. 产生环境

多个进程(process)、线程(threading)或协程(routine)存在对同一个资源访问顺序敏感(时间上的错误)

2. 概念

  • 临界区 -- 时间上对同一资源的读写产生的数据不一致问题
  • 锁 -- 互斥锁 & 读写锁

4. Demo

// WithLock 进入临界区,同闭包方式访问临界区上下文
func WithLock(l *sync.Mutex, handler func()) {
   l.Lock()
   defer l.Unlock()
   handler()
}

// WithLock 读锁, 进入临界区,同闭包方式访问临界区上下文
func WithRLock(l *sync.RWMutex, handler func()) {
   l.RLock()
   defer l.RUnlock()
   handler()
}

// WithLock 写锁, 进入临界区,同闭包方式访问临界区上下文
func WithWLock(l *sync.RWMutex, handler func()) {
   l.Lock()
   defer l.RUnlock()
   handler()
}
上一篇:技术分享 | 实测在 after_sync 中使用 gh-ost是如何丢数据的


下一篇:Vue .sync修饰符与this.$emit(update:xxx)