回调函数解耦理解

#include <iostream>
#include <string>
#include <functional>
#include <thread>

using namespace std;

using Func = function<void(int)>;  //函数指针 意味着是  void A (int B){} 的函数缩写
using UserFunc = function<void(int,int)>;  //frame_id ,time_stamped
class Driver
{
private:
    Func func;  //函数指针
public:
    void registerCallback(Func f) //注册 ,形参是函数指针
    {
        func = f;
    }

    void start()//底层数据流
    {
        cout << "driver..." << endl;
        int i = 0;
        while(true) 
        {
            func(i); //调用了App端的cb函数,数据后处理交互
            cout << "driver start:" << ++i << endl;
            this_thread::sleep_for(chrono::milliseconds(100)); //睡眠10ms  。
        }
    }
};

class UserDriver
{
private:
    UserFunc func;
public:
    void registerCallback(UserFunc f)
    {
        func = f;
    }
    void callback(int data)
    {   
        cout << "get data" << endl;
        static int frame_id = 1;
        static int time_stamp = 1;
        cout << "ID, Time_stamp:" << frame_id << "," << ++time_stamp << endl;
        func(frame_id,time_stamp);

    }
    void run()
    {

        Func func2 = std::bind(&UserDriver::callback, this, std::placeholders::_1); //回调函数
        Driver driver;
        driver.registerCallback(func2); //注册回调,将app.cb函数指针传到driver层
        driver.start();        
    }
};

class App
{
public:
    App()
    {
        UserFunc func = std::bind(&App::callback, this, std::placeholders::_1, std::placeholders::_2); //回调函数,绑定回调函数app.cb
        // Driver driver;
        // driver.registerCallback(func); //注册回调,将app.cb函数指针传到driver层
        // driver.start();
        UserDriver userdriver;
        userdriver.registerCallback(func);
        userdriver.run();
    }

    void callback(int id, int time_stamp) //后处理函数
    {
        cout << "App_time_stamp:" << time_stamp << endl;
        // cout << "App callback:" << i << endl;
    }
};

int main()
{
    App app;
    return 0;
}

分层用回调函数进行解耦,然后多层回调到最上层。

如上述代码所示,底层驱动获得数据后,进行回调到第二层数据处理UserDriver,进行特殊加工,添加了ID号和数据时间戳,再进行回调到最上层,得到了后处理的数据,可以根据该数据进行相应操作。

因此回调函数的好处在于分层解耦。 比如后续 数据流层->决策层->规划层等都可以进行回调解耦合!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回调函数解耦的例子: 假设有一个图形界面程序,当用户点击一个按钮时,需要执行一段特定的操作,比如显示一个提示框。通过使用回调函数,可以将按钮的点击事件与提示框显示的逻辑解耦解耦的代码示例(JavaScript): ```javascript // 回调函数作为按钮点击事件处理程序 function handleButtonClick() { // 执行一些其他操作 // 调用回调函数显示提示框 showMessageBox("Hello, world!"); } // 定义回调函数,用于显示提示框 function showMessageBox(message) { // 显示提示框的逻辑 console.log("Message: " + message); } ``` 在上述例子中,按钮的点击事件处理程序 `handleButtonClick` 中调用了回调函数 `showMessageBox` 来显示提示框。这样,按钮的点击事件处理逻辑与提示框显示的逻辑被解耦,使得它们可以独立进行修改和扩展。 没有解耦的例子: 如果没有使用回调函数,而是将按钮的点击事件处理程序直接写入显示提示框的代码,那么它们之间就是紧密耦合的。 代码示例(没有解耦): ```javascript // 没有解耦的代码示例 function handleButtonClick() { // 执行一些其他操作 // 直接在按钮点击事件处理程序中显示提示框 console.log("Message: Hello, world!"); } ``` 在这个例子中,按钮的点击事件处理程序直接包含了显示提示框的逻辑。这种紧密耦合的设计使得修改和扩展变得困难,因为每次需要更改提示框的显示方式时,都需要修改按钮点击事件处理程序。这种设计模式缺乏灵活性和可维护性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值