在 Go 语言中,原子包提供较低级别的原子内存,这有助于实现同步算法。 Go 语言中的StoreUint64()函数用于将 val 原子地存储到*addr 中。这个函数是在 atomic 包下定义的。在这里,您需要导入“sync/atomic”包才能使用这些功能。
句法:
func StoreUint64(addr *uint64, val uint64)
这里, addr表示地址。
注意: (*uint64) 是指向 uint64 值的指针。 uint64 是位大小为 64 的整数类型。 然而,int64 包含从 0 到 18446744073709551615 的所有无符号 64 位整数的集合。
返回值:将 val 存储到 *addr 中,然后可以在需要时返回。
示例 1:
// Program to illustrate the usage of
// StoreUint64 function in Golang
// Including main package
package main
// importing fmt and sync/atomic
import (
"fmt"
"sync/atomic"
)
// Main function
func main() {
// Defining variables for the
// address to store the val
var (
x uint64
y uint64
)
// Using StoreUint64 method
// with its parameters
atomic.StoreUint64(&x, 56576656555555)
atomic.StoreUint64(&y, 0)
// Displays the value
// stored in addr
fmt.Println(atomic.LoadUint64(&x))
fmt.Println(atomic.LoadUint64(&y))
}
输出:
56576656555555
0
在这里,首先,uint64 值存储在定义的地址中,然后使用上面的 LoadUint64() 方法返回它们。
示例 2:
// Program to illustrate the usage of
// StoreUint64 function in Golang
// Including main package
package main
// importing fmt and sync/atomic
import (
"fmt"
"sync/atomic"
)
// Main function
func main() {
// Defining variables for
// the address to store the val
var (
x uint64
)
// Using StoreUint64 method
// with its parameters
atomic.StoreUint64(&x, 111776540544)
// Loading the stored val
z := atomic.LoadUint64(&x)
// Prints true if values
// are same else false
fmt.Println(z == x)
// Prints true if addresses
// are same else false
fmt.Println(&z == &x)
}
输出:
true
false
在这里,存储和加载的值相同,因此返回 true 但它们的地址不同,因此在这种情况下返回 false。