sync.Mutex与sync.RWMutex

竞态条件

数据被多个线程共享,那么很可能就产生争用或者冲突,这种场景叫静态条件,这往往会破坏共享数据的一致性。

同步方式

  1. 避免多个线程在同一时刻操作同一个数据块。
  2. 协调多个线程,以避免它们在同一时刻执行同一个代码块。

由于这样的数据块和代码块的背后都隐含着一种或多种资源(比如存储资源、计算资源、I/O 资源、网络资源等等),所以我们可以把它们看做是共享资源,或者说共享资源的代表。我们所说的同步其实就是在控制多个线程对共享资源的访问。

互斥锁

  1. 重复锁定互斥锁,对应的goroutine会则塞在本次lock的代码行,直到有对应的unlock解锁后,它抢到lock权限,才会继续向下进行,所以同一个goroutine重复锁定,必然会形成死锁。
  2. 重复解锁互斥锁,会引发panic。

互斥锁的使用,加锁<=>解锁,要成对出现,为了避免程序分叉,忘记解锁等,要配合defer使用比较好,在lock的后面,及时用defer unlock这样来保证在成对出现。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值