Source File
uint64.go
Belonging Package
go.uber.org/atomic
// @generated Code generated by gen-atomicint.// Copyright (c) 2020-2023 Uber Technologies, Inc.//// Permission is hereby granted, free of charge, to any person obtaining a copy// of this software and associated documentation files (the "Software"), to deal// in the Software without restriction, including without limitation the rights// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell// copies of the Software, and to permit persons to whom the Software is// furnished to do so, subject to the following conditions://// The above copyright notice and this permission notice shall be included in// all copies or substantial portions of the Software.//// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN// THE SOFTWARE.package atomicimport ()// Uint64 is an atomic wrapper around uint64.type Uint64 struct {_ nocmp // disallow non-atomic comparisonv uint64}// NewUint64 creates a new Uint64.func ( uint64) *Uint64 {return &Uint64{v: }}// Load atomically loads the wrapped value.func ( *Uint64) () uint64 {return atomic.LoadUint64(&.v)}// Add atomically adds to the wrapped uint64 and returns the new value.func ( *Uint64) ( uint64) uint64 {return atomic.AddUint64(&.v, )}// Sub atomically subtracts from the wrapped uint64 and returns the new value.func ( *Uint64) ( uint64) uint64 {return atomic.AddUint64(&.v, ^( - 1))}// Inc atomically increments the wrapped uint64 and returns the new value.func ( *Uint64) () uint64 {return .Add(1)}// Dec atomically decrements the wrapped uint64 and returns the new value.func ( *Uint64) () uint64 {return .Sub(1)}// CAS is an atomic compare-and-swap.//// Deprecated: Use CompareAndSwap.func ( *Uint64) (, uint64) ( bool) {return .CompareAndSwap(, )}// CompareAndSwap is an atomic compare-and-swap.func ( *Uint64) (, uint64) ( bool) {return atomic.CompareAndSwapUint64(&.v, , )}// Store atomically stores the passed value.func ( *Uint64) ( uint64) {atomic.StoreUint64(&.v, )}// Swap atomically swaps the wrapped uint64 and returns the old value.func ( *Uint64) ( uint64) ( uint64) {return atomic.SwapUint64(&.v, )}// MarshalJSON encodes the wrapped uint64 into JSON.func ( *Uint64) () ([]byte, error) {return json.Marshal(.Load())}// UnmarshalJSON decodes JSON into the wrapped uint64.func ( *Uint64) ( []byte) error {var uint64if := json.Unmarshal(, &); != nil {return}.Store()return nil}// String encodes the wrapped value as a string.func ( *Uint64) () string {:= .Load()return strconv.FormatUint(uint64(), 10)}
![]() |
The pages are generated with Golds v0.6.7. (GOOS=linux GOARCH=amd64) Golds is a Go 101 project developed by Tapir Liu. PR and bug reports are welcome and can be submitted to the issue list. Please follow @Go100and1 (reachable from the left QR code) to get the latest news of Golds. |