Source File
uintptr.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 ()// Uintptr is an atomic wrapper around uintptr.type Uintptr struct {_ nocmp // disallow non-atomic comparisonv uintptr}// NewUintptr creates a new Uintptr.func ( uintptr) *Uintptr {return &Uintptr{v: }}// Load atomically loads the wrapped value.func ( *Uintptr) () uintptr {return atomic.LoadUintptr(&.v)}// Add atomically adds to the wrapped uintptr and returns the new value.func ( *Uintptr) ( uintptr) uintptr {return atomic.AddUintptr(&.v, )}// Sub atomically subtracts from the wrapped uintptr and returns the new value.func ( *Uintptr) ( uintptr) uintptr {return atomic.AddUintptr(&.v, ^( - 1))}// Inc atomically increments the wrapped uintptr and returns the new value.func ( *Uintptr) () uintptr {return .Add(1)}// Dec atomically decrements the wrapped uintptr and returns the new value.func ( *Uintptr) () uintptr {return .Sub(1)}// CAS is an atomic compare-and-swap.//// Deprecated: Use CompareAndSwap.func ( *Uintptr) (, uintptr) ( bool) {return .CompareAndSwap(, )}// CompareAndSwap is an atomic compare-and-swap.func ( *Uintptr) (, uintptr) ( bool) {return atomic.CompareAndSwapUintptr(&.v, , )}// Store atomically stores the passed value.func ( *Uintptr) ( uintptr) {atomic.StoreUintptr(&.v, )}// Swap atomically swaps the wrapped uintptr and returns the old value.func ( *Uintptr) ( uintptr) ( uintptr) {return atomic.SwapUintptr(&.v, )}// MarshalJSON encodes the wrapped uintptr into JSON.func ( *Uintptr) () ([]byte, error) {return json.Marshal(.Load())}// UnmarshalJSON decodes JSON into the wrapped uintptr.func ( *Uintptr) ( []byte) error {var uintptrif := json.Unmarshal(, &); != nil {return}.Store()return nil}// String encodes the wrapped value as a string.func ( *Uintptr) () 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. |