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)

相关推荐

  • 怎么理解MySQL的innodb_flush_method

    技术怎么理解MySQL的innodb_flush_method这篇文章主要讲解了“怎么理解MySQL的innodb_flush_method”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一

    攻略 2021年11月19日
  • Burp+夜神模拟器抓包

    技术Burp+夜神模拟器抓包 Burp+夜神模拟器抓包Burp+夜神模拟器抓包
    0X00-引言知己知彼,将心比心。
    酒逢知己饮,诗向会人吟。
    相识满天下,知己能几人。
    相逢好似初相识,到老终无怨恨心。

    礼包 2021年12月10日
  • 如何进行null与index的分析

    技术如何进行null与index的分析这期内容当中小编将会给大家带来有关如何进行null与index的分析,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。今天在测试过程中遇到一问题, S

    攻略 2021年11月30日
  • javascript中怎么实现一个基于DOM的模板引擎

    技术javascript中怎么实现一个基于DOM的模板引擎本篇内容主要讲解“javascript中怎么实现一个基于DOM的模板引擎”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习

    攻略 2021年11月15日
  • 唐僧性格,唐僧的人物性格,300字

    技术唐僧性格,唐僧的人物性格,300字唐 僧唐僧性格:俗家姓陈,乳名江流,法名玄奘,唐朝第一高僧,所以被人们称为唐僧。西行取经时,唐朝太宗皇帝李世民赐法名三藏。唐僧十八岁出家皈依佛门,经常青灯夜读,对佛家经典研修不断,而

    生活 2021年10月26日
  • Python用哪些工具好

    技术Python用哪些工具好这篇文章主要介绍了Python用哪些工具好,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、最强终端:Upterm本来想推荐

    攻略 2021年10月28日