C++笔记 -- 使用STL的function实现回调机制(回调函数)

1.使用普通函数

示例一

 代码:

#include <iostream>  
#include <functional>  
  
// 定义一个回调函数类型  
using Callback = std::function<void(int)>;  
  
// 定义一个函数,用于演示回调函数的使用  
void performOperation(int data, Callback callback) {  
    // 执行某些操作  
    std::cout << "Performing operation on data: " << data << std::endl;  
    // 调用回调函数  
    callback(data);  
}  
  
// 定义一个回调函数,用于接收操作结果并输出到控制台  
void handleResult(int result) {  
    std::cout << "Result: " << result << std::endl;  
}  
  
int main() {  
    // 调用performOperation函数,并传递一个回调函数作为参数  
    performOperation(100, handleResult);  
  
    return 0;  
}

示例二

  代码:

#include <functional>
#include <iostream>
#include <vector>

class Event {
  public:
    using Callback = std::function<void()>;

    void addCallback(const Callback &cb) {
        callbacks.push_back(cb);
    }

    void trigger() {
        for (const auto &cb : callbacks) {
            cb();
        }
    }

  private:
    std::vector<Callback> callbacks;
};

void callback1() {
    std::cout << "Callback 1 called!" << std::endl;
}

void callback2() {
    std::cout << "Callback 2 called!" << std::endl;
}

int main() {
    Event event;
    event.addCallback(callback1);
    event.addCallback(callback2);

    event.trigger();

    return 0;
}

2.使用匿名函数(Lambda表达式

在这个重写版本中,我们将原来的Lambda表达式替换为了普通函数callback1()和callback2(),然后将它们作为函数指针传递给event.addCallback()。

   代码:

#include <functional>
#include <iostream>
#include <vector>

class Event {
public:
    using Callback = std::function<void()>;

    void addCallback(const Callback& cb) {
        callbacks.push_back(cb);
    }

    void trigger() {
        for (const auto& cb : callbacks) {
            cb();
        }
    }

private:
    std::vector<Callback> callbacks;
};

int main() {
    Event event;
    event.addCallback([]() { std::cout << "Callback 1 called!" << std::endl; });
    event.addCallback([]() { std::cout << "Callback 2 called!" << std::endl; });

    event.trigger();

    return 0;
}

3.使用函数对象(functor)
在这个版本中,我们定义了两个函数对象类Callback1和Callback2,并在这些类中重载了operator()运算符,使它们可以像函数一样被调用。然后,我们创建了cb1和cb2的实例,将它们作为函数对象传递给event.addCallback()。

 

#include <functional>
#include <iostream>
#include <vector>

class Event {
  public:
    using Callback = std::function<void()>;

    void addCallback(const Callback &cb) {
        callbacks.push_back(cb);
    }

    void trigger() {
        for (const auto &cb : callbacks) {
            cb();
        }
    }

  private:
    std::vector<Callback> callbacks;
};

class Callback1 {
  public:
    void operator()() const {
        std::cout << "Callback 1 called!" << std::endl;
    }
};

class Callback2 {
  public:
    void operator()() const {
        std::cout << "Callback 2 called!" << std::endl;
    }
};

int main() {
    Event event;
    Callback1 cb1;
    Callback2 cb2;

    event.addCallback(cb1);
    event.addCallback(cb2);

    event.trigger();

    return 0;
}

4.运行输出

 

posted @ 2023-11-08 18:28  手磨咖啡  阅读(370)  评论(0编辑  收藏  举报