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


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

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

用法:

func LoadUint64(addr *uint64) (val uint64)

在此,addr表示地址。

注意:(* uint64)是指向uint64值的指針。但是,uint64包含從0到18446744073709551615的所有無符號64位整數的集合。

返回值:它返回加載到* addr的值。



範例1:

// Program to illustrate the usage of 
// LoadUint64 function in Golang 
  
// Including main package 
package main 
  
// importing fmt and sync/atomic 
import ( 
    "fmt"
    "sync/atomic"
) 
  
// Main function 
func main() { 
  
    // Assigning values to the uint64 
    var ( 
        i uint64 = 587786787 
        j uint64 = 9 
        k uint64 = 78678844556666 
        l uint64 = 3446 
    ) 
  
    // Calling LoadUint64 method 
    // with its parameters 
    load_1:= atomic.LoadUint64(&i) 
    load_2:= atomic.LoadUint64(&j) 
    load_3:= atomic.LoadUint64(&k) 
    load_4:= atomic.LoadUint64(&l) 
  
    // Displays the uint64 value 
    // loaded in the *addr 
    fmt.Println(load_1) 
    fmt.Println(load_2) 
    fmt.Println(load_3) 
    fmt.Println(load_4) 
}

輸出:

587786787
9
78678844556666
3446

範例2:

// Program to illustrate the usage of 
// LoadUint64 function in Golang 
  
// Including main package 
package main 
  
// Importing fmt and sync/atomic 
import ( 
    "fmt"
    "sync/atomic"
) 
  
// Main function 
func main() { 
  
    // Declaring u 
    var u uint64 
  
    // For loop 
    for i:= 4; i < 200; i += 1 { 
  
        // Function with AddUint64 method 
        go func() { 
            atomic.AddUint64(&u, 6) 
        }() 
    } 
  
    // Prints loaded values address 
    fmt.Println(atomic.LoadUint64(&u)) 
}

輸出:

1068    // A random value is returned in each run

在上麵的示例中,每次調用都會從AddUint64()方法返回新值,直到循環停止為止,LoadUint64()方法將加載這些新uint64值。而且這些值存儲在不同的地址中,該地址可以是隨機的,因此,每次運行中LoadUint32()方法的輸出都是不同的。因此,這裏在輸出中返回一個隨機值。




相關用法


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