En el lenguaje Go, los paquetes atómicos proporcionan una memoria atómica de nivel inferior que es útil para implementar algoritmos de sincronización. La función SwapUintptr() en el lenguaje Go se usa para almacenar atómicamente un nuevo valor en *addr y devuelve el valor anterior de *addr . Esta función se define en el paquete atómico. Aquí, debe importar el paquete «sync/atomic» para usar estas funciones.
Sintaxis:
func SwapUintptr(addr *uintptr, new uintptr) (old uintptr)
Aquí, addr indica dirección. Y new es el nuevo valor de uintptr y old es el valor de uintptr anterior.
Nota: (*uintptr) es el puntero a un valor de uintptr. Y uintptr es un tipo entero que es demasiado grande para que pueda contener el patrón de bits de cualquier puntero.
Valor de retorno: almacena el nuevo valor de uintptr en *addr y devuelve el valor anterior de *addr.
Ejemplo 1:
// Program to illustrate the usage of // SwapUintptr function in Golang // Including main package package main // Importing fmt and sync/atomic import ( "fmt" "sync/atomic" ) // Main function func main() { // Assigning value to uintptr var x uintptr = 96464646466757 // Using SwapUintptr method // with its parameters var old_val = atomic.SwapUintptr(&x, 21863567864) // Prints new and old value fmt.Println("Stored new value: ", x, ", Old value: ", old_val) }
Producción:
Stored new value: 21863567864, Old value: 96464646466757
Ejemplo 2:
// Program to illustrate the usage of // SwapUintptr function in Golang // Including main package package main // Importing fmt and sync/atomic import ( "fmt" "sync/atomic" ) // Main function func main() { // Assigning value to uintptr var m uintptr = 4235564747474 var n uintptr = 2567891937466 // Using SwapUintptr method with its parameters var oldVal1 = atomic.SwapUintptr(&m, 4235564747474) var oldVal2 = atomic.SwapUintptr(&n, 7454545419024) // Prints output fmt.Println((oldVal1) == m) fmt.Println((oldVal2) == n) }
Producción:
true false
Aquí, oldVal1 es igual a «m», ya que el nuevo valor que se almacenará en *addr es el mismo que el valor anterior, por lo que se devuelve verdadero, pero oldVal2 no es igual a «n», ya que el valor anterior no es similar al valor recién asignado, por lo tanto, se devuelve falso.
Publicación traducida automáticamente
Artículo escrito por nidhi1352singh y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA