5 个版本 (3 个重大更改)

0.7.1 2020 年 6 月 4 日
0.7.0 2020 年 6 月 3 日
0.6.6 2020 年 6 月 2 日
0.2.0 2020 年 2 月 20 日
0.1.0 2020 年 2 月 18 日

#async-std 中排名 114

Download history 90/week @ 2024-03-11 95/week @ 2024-03-18 83/week @ 2024-03-25 118/week @ 2024-04-01 65/week @ 2024-04-08 86/week @ 2024-04-15 97/week @ 2024-04-22 83/week @ 2024-04-29 81/week @ 2024-05-06 88/week @ 2024-05-13 81/week @ 2024-05-20 90/week @ 2024-05-27 76/week @ 2024-06-03 47/week @ 2024-06-10 82/week @ 2024-06-17 80/week @ 2024-06-24

每月下载量 299
3 个 crate 中使用(通过 xactor

MIT 许可证 MIT

5KB
58

Xactor 是一个基于 async-std 的 Rust 协程框架

文档

功能

  • 异步协程。
  • 本地环境中的协程通信。
  • 使用 futures 进行异步消息处理。
  • 类型化消息(无 Any 类型)。允许泛型消息。

示例

use xactor::*;

#[message(result = "String")]
struct ToUppercase(String);

struct MyActor;

impl Actor for MyActor {}

#[async_trait::async_trait]
impl Handler<ToUppercase> for MyActor {
    async fn handle(&mut self, _ctx: &mut Context<Self>, msg: ToUppercase) -> String {
        msg.0.to_uppercase()
    }
}

#[xactor::main]
async fn main() -> Result<()> {
    // Start actor and get its address
    let mut addr = MyActor.start().await?;

    // Send message `ToUppercase` to actor via addr
    let res = addr.call(ToUppercase("lowercase".to_string())).await?;
    assert_eq!(res, "LOWERCASE");
    Ok(())
}

性能

https://github.com/sunli829/xactor-benchmarks

安装

Xactor 需要 userland 上的 async-trait

安装 cargo add 后,运行

$ cargo add xactor
$ cargo add async-trait

我们还提供了 tokio 运行时,而不是 async-std。要使用它,您需要激活 runtime-tokio 并禁用默认功能。

您可以按照以下方式编辑您的 Cargo.toml

xactor = { version = "x.x.x", features = ["runtime-tokio"], default-features = false }

参考

依赖

~1.5MB
~34K SLoC