atomic_swapping 0.1.0

An arbitrary type atomic storage with swap operations
Documentation
  • Coverage
  • 100%
    27 out of 27 items documented27 out of 27 items with examples
  • Size
  • Source code size: 49.19 kB This is the summed size of all the files inside the crates.io package for this release.
  • Documentation size: 391.67 kB This is the summed size of all files generated by rustdoc for all configured targets
  • Ø build duration
  • this release: 8s Average build duration of successful builds.
  • all releases: 8s Average build duration of successful builds in releases after 2024-10-23.
  • Links
  • Homepage
  • Buzzec/atomic_swapping
    2 0 0
  • crates.io
  • Dependencies
  • Versions
  • Owners
  • Buzzec

atomic_swapping

An arbitrary type atomic storage with swap operations.

This is guaranteed lock-free where atomics will be guaranteed lock-free, however it is not guaranteed wait free. Some operations may spin for a short time. All values will be properly dropped.

use atomic_swapping::option::AtomicSwapOption;

fn main() {
  let swap = AtomicSwapOption::new(Some(100usize));
  assert_eq!(swap.clone_inner(), Some(100usize));
  assert_eq!(swap.take(), Some(100usize));
  assert_eq!(swap.take(), None);
  swap.set(Some(200usize));
  assert_eq!(swap.swap(Some(300usize)), Some(200usize));
  assert!(swap.contains_value());
  assert_eq!(swap.clone_inner(), Some(300usize));
}

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.