在 Go 语言中,原子包提供较低级别的原子内存,这有助于实现同步算法。 Go 语言中的SwapUint64()函数用于将新值原子地存储到*addr 中并返回之前的*addr值。这个函数是在 atomic 包下定义的。在这里,您需要导入“sync/atomic”包才能使用这些功能。
句法:
func SwapUint64(addr *uint64, new uint64) (old uint64)
这里, addr表示地址。 new 是新的 uint64 值,old 是旧的 uint64 值。
注意: (*uint64) 是指向 uint64 值的指针。并且 uint64 是位大小为 64 的整数类型。但是,uint64 包含从 0 到 18446744073709551615 的所有无符号 64 位整数的集合。
返回值:它将新的 uint64 值存储到 *addr 中,并返回之前的 *addr 值。
示例 1:
// Program to illustrate the usage of
// SwapUint64 function in Golang
// Including main package
package main
// Importing fmt and sync/atomic
import (
"fmt"
"sync/atomic"
)
// Main function
func main() {
// Assigning value to uint64
var x uint64 = 10864545453
// Using SwapUint64 method
// with its parameters
var old_val = atomic.SwapUint64(&x, 65353443)
// Prints new and old value
fmt.Println("Stored new value: ",
x, ", Old value: ", old_val)
}
输出:
Stored new value: 65353443, Old value: 10864545453
示例 2:
// Program to illustrate the usage of
// SwapUint64 function in Golang
// Including main package
package main
// Importing fmt and sync/atomic
import (
"fmt"
"sync/atomic"
)
// Main function
func main() {
// Assigning value to uint64
var m uint64 = 11735344343
var n uint64 = 976364747
// Using SwapUint64 method
// with its parameters
var oldVal1 = atomic.SwapUint64(&m, 11735344343)
var oldVal2 = atomic.SwapUint64(&n, 6586850111)
// Prints output
fmt.Println((oldVal1) == m)
fmt.Println((oldVal2) == n)
}
输出:
true
false
在这里, oldVal1等于“m”,因为要存储在 *addr 中的新值与旧值相同,因此返回 true 但oldVal2不等于“n”,因为旧值不类似于因此,新分配的值返回 false。