jason 075d766964 first | há 3 anos atrás | |
---|---|---|
.. | ||
.github | há 3 anos atrás | |
.codecov.yml | há 3 anos atrás | |
.gitignore | há 3 anos atrás | |
.travis.yml | há 3 anos atrás | |
CHANGELOG.md | há 3 anos atrás | |
LICENSE.txt | há 3 anos atrás | |
Makefile | há 3 anos atrás | |
README.md | há 3 anos atrás | |
atomic.go | há 3 anos atrás | |
atomic_test.go | há 3 anos atrás | |
error.go | há 3 anos atrás | |
error_test.go | há 3 anos atrás | |
example_test.go | há 3 anos atrás | |
go.mod | há 3 anos atrás | |
go.sum | há 3 anos atrás | |
stress_test.go | há 3 anos atrás | |
string.go | há 3 anos atrás | |
string_test.go | há 3 anos atrás | |
tools.go | há 3 anos atrás |
Simple wrappers for primitive types to enforce atomic access.
$ go get -u go.uber.org/atomic@v1
Note: If you are using Go modules, this package will fail to compile with the
import path github.com/uber-go/atomic
. To continue using that import path,
you will have to add a replace
directive to your go.mod
, replacing
github.com/uber-go/atomic
with go.uber.org/atomic
.
$ go mod edit -replace github.com/uber-go/atomic=go.uber.org/atomic@v1
The standard library's sync/atomic
is powerful, but it's easy to forget which
variables must be accessed atomically. go.uber.org/atomic
preserves all the
functionality of the standard library, but wraps the primitive types to
provide a safer, more convenient API.
var atom atomic.Uint32
atom.Store(42)
atom.Sub(2)
atom.CAS(40, 11)
See the documentation for a complete API specification.
Stable.
Released under the MIT License.