當前位置: 首頁>>編程示例 >>用法及示例精選 >>正文


Golang atomic.LoadPointer()用法及代碼示例

在Go語言中,原子包提供較低級別的原子內存,這對實現同步算法很有幫助。 Go語言中的LoadPointer()函數用於原子加載* addr。此函數在原子包下定義。在這裏,您需要導入“sync/atomic”和“unsafe”軟件包才能使用這些函數。

用法:

func LoadPointer(addr *unsafe.Pointer) (val unsafe.Pointer)

在此,addr表示地址。

注意:(* unsafe.Pointer)是指向unsafe.Pointer值的指針。而且unsafe.Pointer類型有助於啟用任意類型和內置uintptr類型之間的轉換。此外,不安全是有助於Go程序的類型安全的軟件包。

返回值:它會自動加載* addr並返回unsafe.Pointer。



範例1:

// Program to illustrate the usage of 
// LoadPointer function in Golang 
  
// Including main package 
package main 
  
// importing fmt,  
// sync/atomic and unsafe 
import ( 
    "fmt"
    "sync/atomic"
    "unsafe"
) 
  
// Defining a struct type L 
type L struct{ x, y, z int } 
  
// Declaring pointer  
// to L struct type 
var PL *L 
  
// Calling main 
func main() { 
  
    // Defining *addr unsafe.Pointer 
    var unsafepL = (*unsafe.Pointer)(unsafe.Pointer(&PL)) 
  
    // Defining value  
    // of unsafe.Pointer 
    var px L 
  
    // Calling StorePointer and  
    // storing unsafe.Pointer 
    // value to *addr 
    atomic.StorePointer( 
        unsafepL, unsafe.Pointer(&px)) 
  
    // Calling LoadPointer() method 
    px1:= (*L)(atomic.LoadPointer(unsafepL)) 
  
    // Returns true if *addr is  
    // loaded else returns false 
    fmt.Println(px1 == &px) 
  
    // Prints unsafe.Pointer 
    fmt.Println(&px1) 
}

輸出:

true
0xc0000b8018 // Can be different at different run times

在這裏,StorePointer方法將值添加到* addr,然後LoadPointer方法自動加載* addr。因此,這裏的加載完成了,因此返回true,並且不安全的值。這裏返回的Pointer在不同的運行時間可能會有所不同。

範例2:

// Program to illustrate the usage of 
// LoadPointer function in Golang 
  
// Including main package 
package main 
  
// importing fmt,  
// sync/atomic and unsafe 
import ( 
    "fmt"
    "sync/atomic"
    "unsafe"
) 
  
// Defining a struct type L 
type L struct{ x, y, z int } 
  
// Declaring pointer  
// to L struct type 
var PL *L 
  
// Calling main 
func main() { 
  
    // Defining *addr unsafe.Pointer 
    var unsafepL = (*unsafe.Pointer)(unsafe.Pointer(&PL)) 
  
    // Defining value  
    // of unsafe.Pointer 
    var px L 
  
    // Calling LoadPointer() method 
    px1:= (*L)(atomic.LoadPointer(unsafepL)) 
  
    // Returns true if *addr is  
    // loaded else returns false 
    fmt.Println(px1 == &px) 
  
    // Prints unsafe.Pointer 
    fmt.Println(&px1) 
}

輸出:

false
0xc00000e028  // A random value is returned in each run

在這裏,返回false,因為在此之前不存儲unsafe.pointer,因此LoadPointer()方法無法加載* addr。此外,此處返回的地址值為px1的地址。




相關用法


注:本文由純淨天空篩選整理自nidhi1352singh大神的英文原創作品 atomic.LoadPointer() Function in Golang With Examples。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。