golang中的原子操作atomic包

技术golang中的原子操作atomic包 golang中的原子操作atomic包1. 概念 原子操作 atomic 包 加锁操作涉及到内核态的上下文切换,比较耗时,代价高, 针对基本数据类型我们还可以

golang中的原子操作原子的包

1.概念

原子操作原子的包

加锁操作涉及到内核态的上下文切换,比较耗时,代价高,

针对基本数据类型我们还可以使用原子操作来保证并发的安全,

因为原子操作是去语言提供的方法,我们在用户态就可以完成,因此性能比加锁操作更好

去语言的原子操作由内置的库同步/原子完成

2.原子的包

方法解释func load int 32(addrint 32)(val int 32)

func LoadInt 64(addr ` int 64)(val int 64)brfunc Loaduint32(addruint32)(val uint32)brfunc Loaduint64(addruint64)(val uint64)brfunc Loaduintptr(addruintptr)(val uintptr)brfunc LoadPoint(addrunsafe .指针`)(val不安全。指针)

读取操作

func StoreInt32(addr*int32,val int32)

func StoreInt64(addr*int64,val int64)

func StoreUint32(addr*uint32,val uint32)

func StoreUint64(addr*uint64,val uint64)

func StoreUintptr(addr*uintptr,val uintptr)

函数存储指针(addr *不安全。指针瓦尔不安全。指针)

写入操作

func AddInt32(addr*int32,delta int32)(新Int32)

func AddInt64(addr*int64,delta int64)(新Int64)

func AddUint32(addr*uint32,delta uint32)(新Uint32)

func AddUint64(addr*uint64,delta uint64)(新Uint64)

func AddUintptr(addr*Uintptr,delta uintptr)(新uintptr)

修改操作

func SwapInt32(addr*int32,new int32) (old int32)

func SwapInt64(addr*int64,new int64) (old int64)

func Swapuit 32(addr * uint 32,新Uint32()旧uint32)

func SwapUint64(addr*uint64,新Uint64()旧uint64)

func SwapUintptr(addr*Uintptr,new uintptr)(旧uintptr)

func SwapPointer(addr *不安全。指针,新的不安全。指针)(旧的不安全。指针)

交换操作

func compareandswapint 32(addr * int 32,旧的,新的int 32()已交换bool)

func compareandswapint 64(addr * int 64,旧的,新的int 64()已交换bool)

func CompareAndSwapUint32(addr * Uint 32,旧的,新的uint 32()已交换bool)

func CompareAndSwapUint64(addr * Uint 64,旧的,新的uint 64()已交换bool)

func CompareAndSwapUintptr(addr * Uintptr,旧的,新的uintptr()交换的bool)

func CompareAndSwapPointer(addr *不安全。指针,旧的,新的不安全。指针)(交换的bool)

3.案例比较互斥锁和原子操作的性能

包装主体

导入(

fmt '

同步

"同步/原子"

时间

)

var(

x int64

不愿具体说明自己性别的人士使用的称谓同步。互斥(体)…

工作组同步等待组.

)

//普通函数,并发不安全

func Add(){ 0

x

工作组。完成()

}

//互斥锁,并发安全,性能低于原子操作

func MxAdd(){ 0

mx .锁定()

x

mx .解锁()

工作组。完成()

}

//原子操作,并发安全,性能高于互斥锁,只针对去中的一些基本数据类型使用

func Amadd(){ 0

原子的附件64(x,1)

工作组。完成()

}

func main(){ 0

//原子操作原子的包

//加锁操作涉及到内核态的上下文切换,比较耗时,代价高,

//针对基本数据类型我们还可以使用原子操作来保证并发的安全,

//因为原子操作是去语言提供的方法,我们在用户态就可以完成,因此性能比加锁操作更好

//开始语言的原子操作由内置的库同步/原子完成

开始:=时间。现在()

对于I :=0;我10000;我

工作组。添加(1)

//转到Add() //普通版增加函数不是并发安全的

//go MxAdd() //加锁版增加函数,是并发安全的,但是加锁性能开销大

go AmAdd() //原子操作版增加函数,是并发安全的,性能优于加锁版

}

end :=时间。现在()

工作组。等待()

fmt .Println(x)

fmt .Println(结束.Sub(开始))

}

原子的包提供了底层的原子级内存操作,对于同步算法的实现很有用,这些函数必须谨慎的保证正确使用,除了某些特殊的底层应用,使用通道或者同步包的函数/类型实现同步更好

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/79567.html

(0)

相关推荐

  • docker安装mysql,并navicat远程连接mysql

    技术docker安装mysql,并navicat远程连接mysql docker安装mysql,并navicat远程连接mysql我目前暂用的是mysql5.7版本
    1.拉取mysql镜像docker

    礼包 2021年11月1日
  • 如何实现JavaScript函数式的浅析

    技术如何实现JavaScript函数式的浅析这篇文章给大家介绍如何实现JavaScript函数式的浅析,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。JS函数式浅析0x00 入门的导语(废话)最近两年

    攻略 2021年11月16日
  • CSS兼容中如何进行IE6中背景图片设置

    技术CSS兼容中如何进行IE6中背景图片设置这篇文章将为大家详细讲解有关CSS兼容中如何进行IE6中背景图片设置,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。CSS兼容:

    攻略 2021年11月11日
  • 莱布尼茨公式,牛顿莱布尼茨公式的故事

    技术莱布尼茨公式,牛顿莱布尼茨公式的故事牛顿和莱布尼茨间的故事莱布尼茨公式:1 、1665年夏天,因为英国爆发鼠疫,剑桥大学暂时关闭。刚刚获得学士学位、准备留校任教的
    牛顿被迫离校到他母亲的农场住了一年多。这一年多被称为

    生活 2021年10月22日
  • Hibernate应用开发遇到的问题有哪些

    技术Hibernate应用开发遇到的问题有哪些这篇文章主要讲解了“Hibernate应用开发遇到的问题有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Hibernat

    攻略 2021年12月4日
  • 电脑的用户名和密码怎么查看,宽带用户名和密码怎么查看

    技术电脑的用户名和密码怎么查看,宽带用户名和密码怎么查看宽带用户名和密码查看方法如下电脑的用户名和密码怎么查看:1、首先打开浏览器,然后在地址栏输入路由器在的管理IP地址(地址如果不知道的话,可以看一下路由器背面一般都会

    生活 2021年10月30日