#future #mutex #async #lock #non-blocking #data-structures #version

qutex

基于无锁和其他非(线程)阻塞技术(如 Rust futures)的同步机制,以确保对数据的互斥或共享独占访问

18 个版本

0.2.6 2024年3月25日
0.2.4 2022年8月21日
0.2.3 2019年4月19日
0.2.2 2019年3月8日
0.0.5 2017年3月26日

#292并发

Download history 1388/week @ 2024-04-15 1358/week @ 2024-04-22 913/week @ 2024-04-29 1305/week @ 2024-05-06 1130/week @ 2024-05-13 1216/week @ 2024-05-20 1030/week @ 2024-05-27 1016/week @ 2024-06-03 1147/week @ 2024-06-10 1428/week @ 2024-06-17 1313/week @ 2024-06-24 961/week @ 2024-07-01 999/week @ 2024-07-08 1252/week @ 2024-07-15 1402/week @ 2024-07-22 1183/week @ 2024-07-29

4,940 每月下载量
用于 50 个 Crates (3 直接)

MIT 许可证

54KB
1K SLoC

Qutex

基于 Rust futures 的非线程阻塞队列后端数据锁。

包含 MutexRwLock 的 futures 兼容版本。

文档

示例

Cargo.toml:

[dependencies]
qutex = "0.2"

main.rs:

extern crate qutex;
extern crate futures;

use std::thread;
use futures::Future;
use qutex::Qutex;

fn main() {
    let thread_count = 100;
    let mut threads = Vec::with_capacity(thread_count);
    let start_val = 0;
    let qutex = Qutex::new(start_val);

    for _ in 0..thread_count {
        let future_val = qutex.clone().lock();

        let future_add = future_val.map(|mut val| {
            *val += 1;
        });

        threads.push(thread::spawn(|| {
            future_add.wait().unwrap();
        }));
    }

    for thread in threads {
        thread.join().unwrap();
    }

    let val = qutex.lock().wait().unwrap();
    assert_eq!(*val, start_val + thread_count);
    println!("Qutex final value: {}", *val);
}

依赖

~155–315KB