github.com/zhongdalu/gf@v1.0.0/g/container/gtype/uint64.go (about)

     1  // Copyright 2018 gf Author(https://github.com/zhongdalu/gf). All Rights Reserved.
     2  //
     3  // This Source Code Form is subject to the terms of the MIT License.
     4  // If a copy of the MIT was not distributed with this file,
     5  // You can obtain one at https://github.com/zhongdalu/gf.
     6  
     7  package gtype
     8  
     9  import (
    10  	"sync/atomic"
    11  )
    12  
    13  type Uint64 struct {
    14  	value uint64
    15  }
    16  
    17  // NewUint64 returns a concurrent-safe object for uint64 type,
    18  // with given initial value <value>.
    19  func NewUint64(value ...uint64) *Uint64 {
    20  	if len(value) > 0 {
    21  		return &Uint64{
    22  			value: value[0],
    23  		}
    24  	}
    25  	return &Uint64{}
    26  }
    27  
    28  // Clone clones and returns a new concurrent-safe object for uint64 type.
    29  func (v *Uint64) Clone() *Uint64 {
    30  	return NewUint64(v.Val())
    31  }
    32  
    33  // Set atomically stores <value> into t.value and returns the previous value of t.value.
    34  func (v *Uint64) Set(value uint64) (old uint64) {
    35  	return atomic.SwapUint64(&v.value, value)
    36  }
    37  
    38  // Val atomically loads t.value.
    39  func (v *Uint64) Val() uint64 {
    40  	return atomic.LoadUint64(&v.value)
    41  }
    42  
    43  // Add atomically adds <delta> to t.value and returns the new value.
    44  func (v *Uint64) Add(delta uint64) (new uint64) {
    45  	return atomic.AddUint64(&v.value, delta)
    46  }
    47  
    48  // Cas executes the compare-and-swap operation for value.
    49  func (v *Uint64) Cas(old, new uint64) bool {
    50  	return atomic.CompareAndSwapUint64(&v.value, old, new)
    51  }