libfringe
a Rust library implementing safe, lightweight context switches, without relying on kernel services (by edef1c)
Bus Writer
Single-reader, multi-writer & single-reader, multi-verifier; broadcasts reads to multiple writeable destinations in parallel (by pop-os)
libfringe | Bus Writer | |
---|---|---|
2 | - | |
512 | 26 | |
- | - | |
0.0 | 0.0 | |
over 3 years ago | over 6 years ago | |
Rust | Rust | |
Apache License 2.0 | MIT License |
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
libfringe
Posts with mentions or reviews of libfringe.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2022-09-30.
-
Virtual Threads in Rust?
There’s a bunch of library-based implementations of coroutines for rust. I recall https://github.com/edef1c/libfringe being the most interesting one, but it is quite dated. I don’t think there’s a lot of community interest in stackfull coroutines at this point.
-
Writing Rust the Elixir way
As we saw earlier, scheduling threads is a hard task for the operating system. To replace one thread that's being executed with another one, a lot of work needs to be done (including saving all the registers and some thread state). However, switching between Lunatic Processes does only the minimal amount of work possible. With an idea pioneered by the libfringe library and using some asm! macro magic, Lunatic lets the Rust compiler figure out the minimal number of registers to be preserved during context switches. This makes scheduling Lunatic processes zero-cost. On my machine usually 1ns, equivalent to a function call.
Bus Writer
Posts with mentions or reviews of Bus Writer.
We have used some of these posts to build our list of alternatives
and similar projects.
We haven't tracked posts mentioning Bus Writer yet.
Tracking mentions began in Dec 2020.
What are some alternatives?
When comparing libfringe and Bus Writer you can also consider the following projects:
rayon - Rayon: A data parallelism library for Rust
crossbeam - Tools for concurrent programming in Rust
RxRust - The Reactive Extensions for the Rust Programming Language
coroutine-rs - Coroutine Library in Rust
lunatic - The Lunatic VM [Moved to: https://github.com/lunatic-solutions/lunatic]
actix - Actor framework for Rust.
lucet - Lucet, the Sandboxing WebAssembly Compiler.
yew - Rust / Wasm framework for creating reliable and efficient web applications