1 unstable release
0.1.0 | Jul 30, 2024 |
---|
#1058 in Asynchronous
8KB
97 lines
swait
- A Simple Utility for Blocking on Futures
The swait
library provides a utility to block the current thread until a given future is ready. This is particularly useful in scenarios where asynchronous operations need to be synchronized with blocking code.
The name swait
is derived from the term await
in Rust, indicating a synchronous wait operation.
The swait
library originated from an attempt to improve the performance of the pollster
crate through a pull request, which ultimately did not get merged.
Features
- Blocking on Futures: The primary feature of this library is the ability to block the current thread until a future resolves, providing a seamless bridge between asynchronous and synchronous code.
- Highly Optimized: It uses a lock-free algorithm that provides a highly optimized way to synchronously wait for a future.
- No Unsafe
swait
is simple and does not use any unsafe code.
Installation
To include swait
in your project, add the following to your Cargo.toml
:
[dependencies]
swait = "0.1.0"
Then, include it in your project:
use swait::FutureExt;
Usage
The main API provided by swait
is the FutureExt
trait, which extends the functionality of Rust's Future
trait with the swait
method. This method blocks the current thread until the future is resolved.
Example
use swait::FutureExt;
async fn async_operation() -> i32 {
// Simulating an asynchronous operation
42
}
fn main() {
let result = async_operation().swait();
println!("The result is: {}", result);
}
In this example, async_operation()
is an asynchronous function that returns an i32
. By calling swait()
on it, the main thread blocks until the result is available, and then it prints the result.
API Documentation
FutureExt
Trait
swait
fn swait(self) -> Self::Output
where
Self: Sized;
This method blocks the current thread until the future is ready and returns the output of the future. It is implemented for all types that implement the Future
trait.
swait
Function
pub fn swait<F: Future>(fut: F) -> F::Output
The swait
function is a standalone function that takes a future as an argument and blocks the current thread until the future is resolved.
Internal Implementation
The core of swait
is built around a Signal
structure, which manages the state of the waiting process. The Signal
structure uses atomic operations and thread parking/unparking to efficiently wait for the future to complete.
Signal
Structure
The Signal
structure manages the state of a waiting thread and provides methods to wait for and notify the thread. It uses an AtomicU8
to track the state, which can be WAITING
, PARKED
, or NOTIFIED
.
wait
Method: This method blocks the thread using a combination of spinning, yielding, and parking.notify
Method: This method notifies and wakes the thread if it is parked.
License
This project is licensed under the MIT License. See the LICENSE file for details.
Contribution
Contributions are welcome! Please submit a pull request or open an issue to discuss your ideas.