ringbuf 0.3.1

Lock-free SPSC FIFO ring buffer with direct access to inner data
Documentation
use crate::{LocalRb, SharedRb};

use test::{black_box, Bencher};

const RB_SIZE: usize = 256;
const BATCH_SIZE: usize = 100;

#[bench]
fn push_pop_shared(b: &mut Bencher) {
    let buf = SharedRb::<u64, [_; RB_SIZE]>::default();
    let (mut prod, mut cons) = buf.split();
    prod.push_slice(&[1; RB_SIZE / 2]);
    b.iter(|| {
        prod.push(1).unwrap();
        black_box(cons.pop().unwrap());
    });
}

#[bench]
fn push_pop_local(b: &mut Bencher) {
    let buf = LocalRb::<u64, [_; RB_SIZE]>::default();
    let (mut prod, mut cons) = buf.split();
    prod.push_slice(&[1; RB_SIZE / 2]);
    b.iter(|| {
        prod.push(1).unwrap();
        black_box(cons.pop().unwrap());
    });
}

#[bench]
fn push_pop_x100_immediate(b: &mut Bencher) {
    let buf = SharedRb::<u64, [_; RB_SIZE]>::default();
    let (mut prod, mut cons) = buf.split();
    prod.push_slice(&[1; RB_SIZE / 2]);
    b.iter(|| {
        for _ in 0..BATCH_SIZE {
            prod.push(1).unwrap();
        }
        for _ in 0..BATCH_SIZE {
            black_box(cons.pop().unwrap());
        }
    });
}

#[bench]
fn push_pop_x100_postponed(b: &mut Bencher) {
    let buf = SharedRb::<u64, [_; RB_SIZE]>::default();
    let (mut prod, mut cons) = buf.split();
    prod.push_slice(&[1; RB_SIZE / 2]);
    b.iter(|| {
        {
            let mut prod_cache = prod.postponed();
            for _ in 0..BATCH_SIZE {
                prod_cache.push(1).unwrap();
            }
        }
        {
            let mut cons_cache = cons.postponed();
            for _ in 0..BATCH_SIZE {
                black_box(cons_cache.pop().unwrap());
            }
        }
    });
}