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包的学习与使用的更多相关文章

  1. golang语言中os/signal包的学习与使用

    package main; import ( "os" "os/signal" "fmt" ) //signal包中提供了两个函数 //No ...

  2. golang语言中os/user包的学习与使用

    package main; import ( "os/user" "fmt" ) func main() { //返回当前用户的结构 u, _ := user. ...

  3. golang语言中os/exec包的学习与使用

    package main; import ( "os/exec" "fmt" "io/ioutil" "bytes" ) ...

  4. go语言中os/signal包的学习与使用

    package main; import ( "os" "os/signal" "fmt" ) //signal包中提供了两个函数 //No ...

  5. php 中函数获取可变参数的方法, 这个语法有点像 golang 语言中的

    原文呢:http://php.net/manual/en/functions.arguments.php#functions.arguments.type-declaration.strict Onl ...

  6. golang中的原子操作atomic包

    1. 概念 原子操作 atomic 包 加锁操作涉及到内核态的上下文切换,比较耗时,代价高, 针对基本数据类型我们还可以使用原子操作来保证并发的安全, 因为原子操作是go语言提供的方法,我们在用户态就 ...

  7. golang语言中os包的学习与使用(文件,目录,进程的操作)

    os中一些常用函数的使用: package main; import ( "os" "fmt" "time" "strings&q ...

  8. go语言中sync包和channel机制

    文章转载至:https://www.bytelang.com/article/content/A4jMIFmobcA= golang中实现并发非常简单,只需在需要并发的函数前面添加关键字"Go&quo ...

  9. golang语言中bytes包的常用函数,Reader和Buffer的使用

    bytes中常用函数的使用: package main; import ( "bytes" "fmt" "unicode" ) //byte ...

随机推荐

  1. Java设置运行时环境参数

    一.代码中,如下: System.setProperty("java.util.concurrent.ForkJoinPool.common.parallelism", " ...

  2. ReactiveX 学习笔记(5)合并数据流

    Combining Observables 本文的主题为合并 Observable 的操作符. 这里的 Observable 实质上是可观察的数据流. RxJava操作符(四)Combining An ...

  3. 趣味编程:静夜思(Kotlin版)

    import java.util.* fun verticalWriting(txt:String, offset:Int) = txt.mapIndexed { i, c -> Pair(i, ...

  4. SQL Server 中BIT类型字段增删查改那点事

    话说BIT类型字段之前,先看“诡异”的一幕,执行Update成功,但是查询出来的结果依然是1,而不是Update的2 当别人问起我来的时候,本人当时也是处于懵逼状态的,后面联想具体的业务突然想起来这个 ...

  5. Cache雪崩效应

    大概半年前,Guang.com曾发生一次由于首页部分cache失效,导致网站故障. 故障分析: 当时逛正在做推广,流量突然暴增,QPS达到5000+,当首页部分cache失效时,需要查询DB, 但由于 ...

  6. spring使用中ModelAttribute的内容被覆盖

    在前台以get方式向后台提交数据: 后台接收: 后台接收参数的时候,由于user里面也有一个属性为id,后台在接收参数的时候,User里面的id会被重新赋值,这是一个大坑.如果后续继续用User来做操 ...

  7. Microsoft® SQL Server® 2012 功能包

    Microsoft® SQL Server® 2012 功能包 http://www.microsoft.com/zh-cn/download/details.aspx?id=29065 Micros ...

  8. CSS 字体风格

    粗体 font-weight 属性可以设置文本的粗细. 它有两个属性: normal 普通粗细 bold 粗文本 示例: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 ...

  9. SpringJDBC数据库的基本使用

    SpringJDBC的基础使用部分内容 云笔记项目数据库部分采用的是Spring-MyBatis,前面学过了JDBC,SpringJDBC,Mybatis和Spring-MyBatis,有必要重新复习 ...

  10. pycharm破解版