4 releases

0.1.3 Jan 10, 2024
0.1.2 Oct 27, 2022
0.1.1 Oct 27, 2022
0.1.0 Oct 27, 2022

#155 in Concurrency

Download history 21184/week @ 2024-09-21 19686/week @ 2024-09-28 22113/week @ 2024-10-05 23336/week @ 2024-10-12 25335/week @ 2024-10-19 23707/week @ 2024-10-26 26857/week @ 2024-11-02 25557/week @ 2024-11-09 24306/week @ 2024-11-16 24916/week @ 2024-11-23 27908/week @ 2024-11-30 30465/week @ 2024-12-07 26349/week @ 2024-12-14 9341/week @ 2024-12-21 11875/week @ 2024-12-28 22546/week @ 2025-01-04

75,676 downloads per month
Used in 52 crates (via dhat)

Apache-2.0

7KB
127 lines

mintex

A minimal Mutex

A drop-in for std::sync::Mutex which doesn't do poisoning. The lock will spin and yield if the lock isn't acquired. The implementation doesn't attempt to be "fair", but because it's so simple it is fast.

The main reason for it to exist, is because I know it does not allocate memory during execution and that's a desirable feature for some use cases.

I have run the tests under miri and no issues are detected.

Crates.io

API Docs

Installation

[dependencies]
mintex = "0.1"

License

Apache 2.0 licensed. See LICENSE for details.


lib.rs:

mintex is a minimal Mutex.

Most of the implementation is lifted from std::sync::Mutex. The reason for this mutex existing is that I'd like a mutex which is quite lightweight and does not perform allocations.

No runtime deps