5 个版本

0.4.0 2022年3月23日
0.3.3 2022年3月22日
0.3.2 2022年3月17日
0.3.1 2022年3月17日
0.3.0 2022年3月17日

#971 in 并发

Download history 895/week @ 2024-03-06 673/week @ 2024-03-13 1511/week @ 2024-03-20 779/week @ 2024-03-27 719/week @ 2024-04-03 1652/week @ 2024-04-10 592/week @ 2024-04-17 843/week @ 2024-04-24 712/week @ 2024-05-01 610/week @ 2024-05-08 488/week @ 2024-05-15 623/week @ 2024-05-22 930/week @ 2024-05-29 1029/week @ 2024-06-05 822/week @ 2024-06-12 957/week @ 2024-06-19

3,857 每月下载量
用于 6 个 crates (2 直接)

MIT 许可证

5KB
73

Tabnine 用 ❤️ 开发

Proc-lock

一个简单的跨进程锁定 API。

快速入门

安装

在您的 Cargo.toml 文件中,添加

[dependencies]
proc-lock = "*"

直接使用 API

use proc_lock::{lock, LockPath};

fn main() {
    let lock_path = LockPath::Tmp("my_lock.lock");
    let guard = lock(&lock_path).unwrap();
    // Until `guard` is dropped, this code section is atomic across multiple processes.
    // ...
    drop(guard);
}

使用宏

use proc_lock::proclock;

fn main() {
 // A lock will be acquired at the beginning of this function, and will be released at the end.
 a_sensitive_function();
}

#[proc_lock(name = "my_lock.lock")]
fn a_sensitive_function() {}

当前状态

⚠️此 crate 处于早期阶段,预计未来版本会有重大更改。

更新日志

  • 0.4.0 - 将依赖关系更改为本地以改善开发过程
  • 0.3.3 - 修改文档
  • 0.3.2 - 修复宏编译
  • 0.3.1 - 修改文档
  • 0.3.0 - [重大更改] 将 crate 重命名为 proc-lock,并将宏重命名为 proc_lock
  • 0.2.1 - 添加有关重命名 crate 的说明
  • 0.2.0 - [重大更改] 停止支持非阻塞宏 API

贡献

请参阅 我们的项目,以及开放的问题。

也可以自由讨论和提交 PR :)

依赖项

~250KB