github.com/zhongdalu/gf@v1.0.0/g/container/gtype/int.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 Int struct {
    14  	value int64
    15  }
    16  
    17  // NewInt returns a concurrent-safe object for int type,
    18  // with given initial value <value>.
    19  func NewInt(value ...int) *Int {
    20  	if len(value) > 0 {
    21  		return &Int{
    22  			value: int64(value[0]),
    23  		}
    24  	}
    25  	return &Int{}
    26  }
    27  
    28  // Clone clones and returns a new concurrent-safe object for int type.
    29  func (v *Int) Clone() *Int {
    30  	return NewInt(v.Val())
    31  }
    32  
    33  // Set atomically stores <value> into t.value and returns the previous value of t.value.
    34  func (v *Int) Set(value int) (old int) {
    35  	return int(atomic.SwapInt64(&v.value, int64(value)))
    36  }
    37  
    38  // Val atomically loads t.value.
    39  func (v *Int) Val() int {
    40  	return int(atomic.LoadInt64(&v.value))
    41  }
    42  
    43  // Add atomically adds <delta> to t.value and returns the new value.
    44  func (v *Int) Add(delta int) (new int) {
    45  	return int(atomic.AddInt64(&v.value, int64(delta)))
    46  }
    47  
    48  // Cas executes the compare-and-swap operation for value.
    49  func (v *Int) Cas(old, new int) bool {
    50  	return atomic.CompareAndSwapInt64(&v.value, int64(old), int64(new))
    51  }