Concurrently modify same atomic in stress tests (#33)

Currently, the stress tests start multiple goroutines, but they all have
their own local atomic, so they are not concurrently modifying the same
values. Return a function which can be run concurrently to modify the
same atomic.
1 file changed
tree: 0a701aa11202f5db05c4b8278d7c8f7cc725403d
  1. .github/
  2. scripts/
  3. .codecov.yml
  4. .gitignore
  5. .travis.yml
  6. atomic.go
  7. atomic_test.go
  8. example_test.go
  9. glide.lock
  10. glide.yaml
  11. LICENSE.txt
  12. Makefile
  13. README.md
  14. stress_test.go
  15. string.go
  16. string_test.go
README.md

atomic GoDoc Build Status Coverage Status Go Report Card

Simple wrappers for primitive types to enforce atomic access.

Installation

go get -u go.uber.org/atomic

Usage

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.

Development Status

Stable.