Rust CallBack的几种写法

模拟常用的几种函数调用CallBack的写法。测试调用都放在函数t6_call_back_task中。我正在学习Rust,有不对或者欠缺的地方,欢迎交流指正

rust 复制代码
type Callback = std::sync::Arc<dyn Fn() + Send + Sync>;
type CallbackReturnVal = std::sync::Arc<dyn Fn() -> Result<String, i32> + Send + Sync>;
type CallbackResult = std::sync::Arc<dyn Fn(Result<String, i32>) + Send + Sync>;


pub(crate) trait EventListener {
    fn on_action1(&self, code: i32);
    fn on_action2(&self, val: String, code: i32);
}

pub(crate) struct Executor {
    call_back: fn(),
    call_back2: core::option::Option<Callback>,
    call_back3: core::option::Option<CallbackReturnVal>,
    call_back4: core::option::Option<CallbackResult>,
    listener: Box<dyn EventListener + 'static>,
}

struct DefaultEventListener;

impl EventListener for DefaultEventListener {
    fn on_action1(&self, code: i32) {}

    fn on_action2(&self, val: String, code: i32) {}
}

impl Executor {
    pub fn new() -> Self {
        let default_callback: fn() = || {
            println!("Default callback executed");
        };

        Executor {
            call_back: default_callback,
            call_back2: None,
            call_back3: None,
            call_back4: None,
            listener: Box::new(DefaultEventListener {}),
        }
    }

    pub fn set_call_back(&mut self, cb: fn()) {
        self.call_back = cb;
    }

    pub fn set_call_back2<CB>(&mut self, call_back: CB)
        where CB: Fn() + Send + Sync + 'static {
        self.call_back2 = Some(std::sync::Arc::new(call_back));
    }

    pub fn set_call_back3<CB>(&mut self, call_back: CB)
        where CB: Fn() -> Result<String, i32> + Send + Sync + 'static {
        self.call_back3 = Some(std::sync::Arc::new(call_back));
    }

    pub fn set_call_back4<CB>(&mut self, call_back: CB)
        where CB: Fn(Result<String, i32>) + Send + Sync + 'static {
        self.call_back4 = Some(std::sync::Arc::new(call_back));
    }

    pub fn set_call_back5(&mut self, listener: Box<dyn EventListener + 'static>) {
        self.listener = listener;
    }

    pub fn process_events(&self) {
        (self.call_back)();

        //call_back2
        if let Some(call_back2_type) = &self.call_back2 {
            call_back2_type();
            call_back2_type();
        } else {
            println!("No callback2 to execute.");
        }

        //call_back3
        if let Some(call_back3_type) = &self.call_back3 {
            let result = call_back3_type();
        } else {
            println!("No callback3 to execute.");
        }

        //call_back4
        if let Some(call_back4_type) = &self.call_back4 {
            let ok: Result<String, i32> = Result::Ok("success".to_string());
            let error_code: Result<String, i32> = Result::Err(-10);
            call_back4_type(ok);
        } else {
            println!("No callback4 to execute.");
        }

        //call_back5
        self.listener.on_action1(1);
        self.listener.on_action2("".to_string(), -1);
    }
}

pub(crate) struct EventListenerImpl {}

impl EventListener for EventListenerImpl {
    fn on_action1(&self, code: i32) {
        println!("-------on_action1--------code: {}", code);
    }

    fn on_action2(&self, val: String, code: i32) {
        println!("-------on_action2--------code: {} , val: {}", code, val);
    }
}

pub(crate) fn t6_call_back_task() {
    let mut executor = Executor::new();
    executor.set_call_back(|| {
        println!("-------call_back----1----");
    });

    executor.set_call_back2(|| {
        println!("-------call_back----2----");
    });

    executor.set_call_back3(|| {
        println!("-------call_back----3---");
        Ok("Callback executed successfully!".to_string())
    });

    executor.set_call_back4(|result: Result<String, i32>| {
        println!("-------call_back----4----result: {:?}", result);
    });

    let event_listener = Box::new(EventListenerImpl {});
    executor.set_call_back5(event_listener);

    executor.process_events();
}
相关推荐
星栈18 小时前
我用 Rust + Dioxus 做了个全栈跨平台笔记应用:再把新建、编辑和交付补上
前端·rust·前端框架
独孤留白1 天前
从C到Rust:基本类型 C 的隐式不确定 vs Rust 的显式确定
rust
清晨很温柔啊1 天前
# 用 Rust 手搓 AI 自演化主板:当 18 个异构器官长出 C++ 骨骼
rust
星栈2 天前
我用 Rust + Dioxus 做了个全栈跨平台笔记应用:第一版先把列表和详情跑通
前端·rust·前端框架
doiito2 天前
【Agent Harness】Gliding Horse 工具结果压缩体系:如何用“指针”驯服上下文膨胀
ai·rust·架构设计·系统设计·ai agent
星栈3 天前
Dioxus 接数据库最容易写歪的 3 个地方:sqlx + SQLite 怎么接才顺
前端·rust·前端框架
独孤留白3 天前
从C到Rust:移动语义、引用传递与生命周期——一次讲清楚
rust
星栈3 天前
Dioxus 表单处理:从输入、校验到文件上传,一条链路讲透
前端·rust·前端框架
doiito3 天前
【Agent Harness】Gliding Horse 上下文动态感知与智能压缩:让 Agent 真正“听得进”每一句话
ai·rust·架构设计·系统设计·ai agent