[Go]golang原子函数锁住共享资源
atomic包里的几个函数以及sync包里的mutex类型,提供了解决方案
原子函数能够以很底层的加锁机制来同步访问整型变量和指针
(&counter,1)的原理[Go]golang原子函数锁住共享资源
atomic包里的几个函数以及sync包里的mutex类型,提供了解决方案
原子函数能够以很底层的加锁机制来同步访问整型变量和指针
(&counter,1)的原理是强制同一时刻只能有一个goroutine运行并完成这个加法操作
packagemain
import(
"fmt"
"runtime"
"sync"
"sync/atomic"
)
var(
//全局变量
counterint64
//计数信号量
)
funcmain(){
("hello")
〃计数加2,等待两个goroutine
(2)
goincCounter()
goincCounter()
〃主goroutine等待子goroutine结束
()
:",counter)
}
〃增加counter的值函数
funcincCounter(){
〃函数结束,减小信号量
()
forcount:=0;count<2;count++{
〃安全的对counter加1
(&counter,1)
//强制调度器必须切换
()
}
}
[Go]golang原子函数锁住共享资源 来自淘豆网www.taodocs.com转载请标明出处.