Do函数里面 刚开始进来的时候,直接用0.done == 0 判断也能达到效果,atomic.LoadUint32(&o.done) == 0目的是啥,为了很多goroutine同时调用Do函数,减少o.m.Lock()的调用吗
疑问不在于为什么有了原子操作还要加锁,而是有了加锁还要用原子操作,
如下写法会有线程安全问题吗?
```go
type Once struct {
done uint32
m Mutex
}
func (o *Once) Do(f func()) {
if o.done == 0 {
o.doSlow(f)
}
}
func (o *Once) doSlow(f func()) {
o.m.Lock()
defer o.m.Unlock()
if o.done == 0 {
defer o.done = 1
f()
}
}
```
#8
更多评论
<a href="/user/kingJ" title="@kingJ">@kingJ</a> 线程安全是指啥,两个goroutine同时读一个int应该不会panic
#2