atomic包提供了底层的原子级内存操作,对于同步算法的实现很有用。
import “sync/atomic”
func LoadUint64(addr *uint64) (val uint64)
LoadUint64原子性的获取*addr的值。
func StoreUint64(addr *uint64, val uint64)
StoreUint64原子性的将val的值保存到*addr。
package main
import (
"fmt"
"sync/atomic"
)
func main() {
var peakMemAlloc uint64
fmt.Println(peakMemAlloc)
if atomic.LoadUint64(&peakMemAlloc) < 10 {
atomic.StoreUint64(&peakMemAlloc, 10)
}
fmt.Println(peakMemAlloc)
}
运行结果:
0
10
func LoadPointer(addr *unsafe.Pointer) (val unsafe.Pointer)
LoadPointer原子性的获取*addr的值。
func StorePointer(addr *unsafe.Pointer, val unsafe.Pointer)
StorePointer原子性的将val的值保存到*addr。
package main
import (
"fmt"
"sync/atomic"
)
func main() {
var sender atomic.Value
sender.Store("Hello")
fmt.Println(sender.Load())
}
运行结果
Hello
package main
import (
"fmt"
"math/big"
)
func main() {
total := new(big.Int)
a := new(big.Int).SetUint64(10)
b := new(big.Int).Set(a)
fmt.Println("b : ", b)
total.Mul(a, new(big.Int).SetUint64(20))
fmt.Println("total : ", total)
total.Mul(a, new(big.Int).SetUint64(20))
fmt.Println("total : ", total)
}
运行结果:
b : 10
total : 200
total : 200