golang语言中sync/atomic包的学习与使用
package main; import (
"sync/atomic"
"fmt"
"sync"
) //atomic包提供了底层的原子级内存操作
//类型共有六种:int32, int64, uint32, uint64, uintptr, unsafe.Pinter
//操作共五种:增减, 比较并交换, 载入, 存储,交换 func main() { //增减操作
var a int32;
fmt.Println("a : ", a);
//函数名以Add为前缀,加具体类型名
//参数一,是指针类型
//参数二,与参数一类型总是相同
//增操作
new_a := atomic.AddInt32(&a, 3);
fmt.Println("new_a : ", new_a);
//减操作
new_a = atomic.AddInt32(&a, -2);
fmt.Println("new_a : ", new_a); //CAS(Compare And Swap)比较并交换操作
//函数名以CompareAndSwap为前缀,并具体类型名
var b int32;
fmt.Println("b : ", b);
//函数会先判断参数一指向的值与参数二是否相等,如果相等,则用参数三替换参数一的值。
//最后返回是否替换成功
atomic.CompareAndSwapInt32(&b, 0, 3);
fmt.Println("b : ", b); //载入操作
//当我们对某个变量进行读取操作时,可能该变量正在被其他操作改变,或许我们读取的是被修改了一半的数据。
//所以我们通过Load这类函数来确保我们正确的读取
//函数名以Load为前缀,加具体类型名
var c int32;
wg := sync.WaitGroup{};
//我们启100个goroutine
for i := 0; i < 100; i++ {
wg.Add(1);
go func() {
defer wg.Done();
tmp := atomic.LoadInt32(&c);
if !atomic.CompareAndSwapInt32(&c, tmp, (tmp + 1)) {
fmt.Println("c 修改失败");
}
}();
}
wg.Wait();
//c的值有可能不等于100,频繁修改变量值情况下,CAS操作有可能不成功。
fmt.Println("c : ", c); //存储操作
//与载入函数相对应,提供原子的存储函数
//函数名以Store为前缀,加具体类型名
var d int32;
fmt.Println("d : ", d);
//存储某个值时,任何CPU都不会都该值进行读或写操作
//存储操作总会成功,它不关心旧值是什么,与CAS不同
atomic.StoreInt32(&d, 666);
fmt.Println("d : ", d); //交换操作
//直接设置新值,返回旧值,与CAS不同,它不关心旧值。
//函数名以Swap为前缀,加具体类型名
var e int32;
wg2 := sync.WaitGroup{};
//我们启10个goroutine
for i := 0; i < 10; i++ {
wg2.Add(1);
go func() {
defer wg2.Done();
tmp := atomic.LoadInt32(&e);
old := atomic.SwapInt32(&e, (tmp + 1));
fmt.Println("e old : ", old);
}();
}
wg2.Wait();
fmt.Println("e : ", e);
}
golang语言中sync/atomic包的学习与使用的更多相关文章
- golang语言中os/signal包的学习与使用
package main; import ( "os" "os/signal" "fmt" ) //signal包中提供了两个函数 //No ...
- golang语言中os/user包的学习与使用
package main; import ( "os/user" "fmt" ) func main() { //返回当前用户的结构 u, _ := user. ...
- golang语言中os/exec包的学习与使用
package main; import ( "os/exec" "fmt" "io/ioutil" "bytes" ) ...
- go语言中os/signal包的学习与使用
package main; import ( "os" "os/signal" "fmt" ) //signal包中提供了两个函数 //No ...
- php 中函数获取可变参数的方法, 这个语法有点像 golang 语言中的
原文呢:http://php.net/manual/en/functions.arguments.php#functions.arguments.type-declaration.strict Onl ...
- golang中的原子操作atomic包
1. 概念 原子操作 atomic 包 加锁操作涉及到内核态的上下文切换,比较耗时,代价高, 针对基本数据类型我们还可以使用原子操作来保证并发的安全, 因为原子操作是go语言提供的方法,我们在用户态就 ...
- golang语言中os包的学习与使用(文件,目录,进程的操作)
os中一些常用函数的使用: package main; import ( "os" "fmt" "time" "strings&q ...
- go语言中sync包和channel机制
文章转载至:https://www.bytelang.com/article/content/A4jMIFmobcA= golang中实现并发非常简单,只需在需要并发的函数前面添加关键字"Go&quo ...
- golang语言中bytes包的常用函数,Reader和Buffer的使用
bytes中常用函数的使用: package main; import ( "bytes" "fmt" "unicode" ) //byte ...
随机推荐
- Shoulda, Woulda, Coulda
Shoulda, Woulda, Coulda Share Tweet Share Tagged With: Should-Would-Could, Words that Begin with H R ...
- C++中文件读写的操作
在C++中读读写文件一般指的就是磁盘中的文本文件和二进制文件: 文本文件:以字符序列组成的文件 二进制文件:由二进制组成的文件 读写文件采用ofstream和ifstream文件流,两者可用头文件&l ...
- [CI]CodeIgniter快速开发指南
---------------------------------------------------------------------------------------------------- ...
- ArcGIS案例学习笔记4_2_城乡规划容积率计算和建筑景观三维动画
ArcGIS案例学习笔记4_2_城乡规划容积率计算和建筑景观三维动画 概述 计划时间:第4天下午 目的:城市规划容积率计算和建筑三维景观动画 教程: pdf page578 数据:实验数据\Chp13 ...
- C#自制Web 服务器开发:mysql免安装版配置步骤详解分享
mysql免安装版配置步骤详解分享 1.准备工作 下载mysql的最新免安装版本mysql-noinstall-5.1.53-win32.zip,解压缩到相关目录,如:d:\ mysql-noinst ...
- FMS Dev Guide学习笔记(权限控制)
一.开发交互式的媒体应用程序 1.关于访问(权限)控制 当一个用户访问服务器的时候,默认情况下,他可以访问所有的流媒体文件和共享对象.但是你可以使用服务端ActionScript为流媒体文件和 ...
- debug.keystare找不到的解决办法[转]
重装系统之后,丢失了debug.keystore,找了很久都没有找到,根据网上所讲的只要重新运行一个android项目;就会在avd中生成一个新的debug.keystroe,此法也没解决,索性直接重 ...
- ubuntu16.04 64bit 升级到 python3.6
https://blog.csdn.net/zhao__zhen/article/details/81584933 https://www.codetd.com/article/1967538 htt ...
- Ik分词器没有使用---------elasticsearch-analysis-ik 5.6.3分词问题
此文章在作者认真阅读源码后发现,这并不是问题所在. 此篇文章是对IK配置的错误理解.新版本的IK配置的扩展字典本来就该使用者自己去手动配置! 1.问题 现在项目中用的是ES5.6.3的版本,在解决Fi ...
- 表的转置 行转列: DECODE(Oracle) 和 CASE WHEN 的异同点
异同点 都可以对表行转列: DECODE功能上和简单Case函数比较类似,不能像Case搜索函数一样,进行更复杂的判断 在Case函数中,可以使用BETWEEN, LIKE, IS NULL, IN, ...