all options
bullseye  ] [  bookworm  ] [  trixie  ] [  sid  ]
[ Source: libatomic-queue  ]

Package: libatomic-queue0 (0.0+git20201108.d9d66b6-2)

Links for libatomic-queue0

Screenshot

Debian Resources:

Download Source Package libatomic-queue:

Maintainers:

External Resources:

Similar packages:

C++ atomic_queue library

C++11 multiple-producer-multiple-consumer lockless queues based on circular buffer with std::atomic. The main design principle these queues follow is simplicity: the bare minimum of atomic operations, fixed size buffer, value semantics.

The circular buffer side-steps the memory reclamation problem inherent in linked-list based queues for the price of fixed buffer size. See Effective memory reclamation for lock-free data structures in C++ for more details.

These qualities are also limitations:

 * The maximum queue size must be set at compile time or construction time.
 * There are no OS-blocking push/pop functions.

Nevertheless, ultra-low-latency applications need just that and nothing more. The simplicity pays off, see the throughput and latency benchmarks.

Available containers are:

 * AtomicQueue - a fixed size ring-buffer for atomic elements.
 * OptimistAtomicQueue - a faster fixed size ring-buffer for atomic
   elements which busy-waits when empty or full.
 * AtomicQueue2 - a fixed size ring-buffer for non-atomic elements.
 * OptimistAtomicQueue2 - a faster fixed size ring-buffer for non-atomic
   elements which busy-waits when empty or full.

These containers have corresponding AtomicQueueB, OptimistAtomicQueueB, AtomicQueueB2, OptimistAtomicQueueB2 versions where the buffer size is specified as an argument to the constructor.

This package contains the dynamic library.

Other Packages Related to libatomic-queue0

  • depends
  • recommends
  • suggests
  • enhances

Download libatomic-queue0

Download for all available architectures
Architecture Package Size Installed Size Files
amd64 55.0 kB224.0 kB [list of files]