simple_mutex 2.0.1 copy "simple_mutex: ^2.0.1" to clipboard
simple_mutex: ^2.0.1 copied to clipboard

Simple but the best Mutex providing a exclusive write lock and shared read-only locks.

Simple Mutex #

This provids a exclusive write lock and shared read-only locks.

Request for exclusive lock can gracefully interrupt multiple parallel loops acquiring shared locks.

Features #

  • Literally mutually exclusive lock, for read/ write user of resources.
  • Shared locks, for read-only users.
  • Eclusive critical section helper with retrun value.
  • Shared critical section helper with return value.

Getting started #

import 'simple_mutex/simple_mutex.dart';

Usage #

Declaration.

final mutex = Mutex();

Protect asynchronous critical section with mutually exclusive lock.

await mutex.lock();
try {
  // Some mutually exclusive asynchronous critical section.
  // This prevent entering other mutually exclusive/ shared critical sections.
} finally {
  mutex.unlock();
}

Protect asynchronous critical section with shared lock.

await mutex.lockShared();
try {
  // Some shared asynchronous critical section.
  // This prevent entering other mutually exclusive critical sections.
  // On the other hand, this can be run in parallel with other shared 
  // critical sections.
} finally {
  mutex.unlockShared();
}

To avoid leaking lock in exceptional cases, critical and criticalShared are recommended.

Lint unawaited_futures is also recommended, because if you miss await for critical or criticalShared, memory would be exhausted.

1
likes
140
pub points
36%
popularity

Publisher

unverified uploader

Simple but the best Mutex providing a exclusive write lock and shared read-only locks.

Repository (GitHub)
View/report issues

Documentation

API reference

License

BSD-3-Clause (LICENSE)

More

Packages that depend on simple_mutex