sync/atomic 库使用小结
来源:互联网 发布:剑灵人族捏脸数据大全 编辑:程序博客网 时间:2024/06/11 23:25
sync/atomic 库提供了原子操作的支持,原子操作直接有底层CPU硬件支持,因而一般要比基于操作系统API的锁方式效率高些。本文对 sync/atomic 中的基本操作进行一个简单的介绍。
原子增值
用于对变量值进行原子增操作,并返回增加后的值。
e.g. var sum uint32 = 100 var wg sync.WaitGroup for i := 0; i < 50; i++ { wg.Add(1) go func() { defer wg.Done() //sum += 1 //1 atomic.AddUint32(&sum, 1) //2 }() } wg.Wait() fmt.Println(sum)
通过对比//1与//2的结果,可以很清楚的看到原子操作起到的作用。使用//1时,可以看到sum的值是不定的,取决于sum的同步访问情况;使用//2时,结果是确定而且正确的,同一时间只有一个goroutine修改sum。
函数原型:
atomic.AddUint32(addr *uint32, delta uint32) uint32 atomic.AddUint64(addr *uint64, delta uint64) uint64 atomic.AddInt32(addr *int32, delta int32) int32 atomic.AddInt64(addr *int64, delta int64) int64 atomic.AddUintptr(addr *uintptr, delta uintptr) uintptr
CAS
先比较变量的值是否等于给定旧值,等于旧值的情况下才赋予新值,最后返回新值是否设置成功。
e.g. var sum uint32 = 100 var wg sync.WaitGroup for i := uint32(0); i < 100; i++ { wg.Add(1) go func(t uint32) { defer wg.Done() atomic.CompareAndSwapUint32(&sum, 100, sum+1) }(i) } wg.Wait() fmt.Println(sum)
可以看到sum的值只改变了一次,只有当sum值为100的时候,CAS才将sum的值修改为了sum+1。
函数原型:
atomic.CompareAndSwapUint32(addr *uint32, old, new uint32) boolatomic.CompareAndSwapUint64(addr *uint64, old, new uint64) boolatomic.CompareAndSwapInt32(addr *int32, old, new int32) boolatomic.CompareAndSwapInt64(addr *int64, old, new int64) boolatomic.CompareAndSwapUintptr(addr *uintptr, old, new uintptr) boolatomic.CompareAndSwapPointer(addr *unsafe.Pointer, old, new unsafe.Pointer) bool
原子导出值
导出变量当前的值。
函数原型:
atomic.LoadUint32(addr *uint32) uint32atomic.LoadUint64(addr *uint64) uint64atomic.LoadInt32(addr *int32) int32atomic.LoadInt64(addr *int64) int64atomic.LoadUintptr(addr *uintptr) uintptratomic.LoadPointer(addr *unsafe.Pointer) unsafe.Pointer
原子导入值
赋予变量新值,而不管它原来是什么值。
函数原型:
atomic.StoreUint32(addr *uint32, val uint32)atomic.StoreUint64(addr *uint64, val uint64)atomic.StoreInt32(addr *int32, val int32)atomic.StoreInt64(addr *int64, val int64)atomic.StoreUintptr(addr *uintptr, val uintptr)atomic.StorePointer(addr *unsafe.Pointer, val unsafe.Pointer)
原子交换值
赋予变量新值,同时返回变量的旧值。
函数原型:
atomic.SwapUint32(addr *uint32, new uint32) old uint32atomic.SwapUint64(addr *uint64, new uint64) old uint64atomic.SwapInt32(addr *int32, new int32) old int32atomic.SwapInt64(addr *int64, new int64) old int64atomic.SwapUintptr(addr *uintptr, new uintptr) old uintptratomic.SwapPointer(addr *unsafe.Pointer, new unsafe.Pointer) old unsafe.Pointer
0 0
- sync/atomic 库使用小结
- sync 库使用小结
- sync/atomic - 原子操作
- OpenThreads库的使用-Atomic
- 日常小结-在内部类中必须使用Atomic原子类替换volatile类
- Atomic使用示例
- browser-sync的使用
- browser-sync的使用
- sync 的使用
- Atomic
- atomic
- Atomic
- Java Atomic的使用总结
- JUC原子类 Atomic***** 使用
- JUC原子类 Atomic***** 使用
- atomic 原子量的使用心得
- 对于sync.Mutex使用注意事项
- browser-sync的安装使用
- 2016年百度校招小结:我做技术面试官的一些思考
- webrtc媒体库封装与测试
- Oracle笔记(四)
- myeclipse开发web service project
- Hibernate查询对象所有字段,单个字段 ,几个字段取值的问题
- sync/atomic 库使用小结
- Audiophobia
- Python 类 setattr、getattr、hasattr 的使用
- android触摸事件分发机制
- 关于java里面注解的理解
- Python中的命令行解析工具介绍
- 如何快速入门产品经理?
- C# 第二天
- 转换xml格式的短信记录