首页 > 后端开发 > C++ > C 11 的 `std::function` 和 `std::bind` 如何解决异构类回调挑战?

C 11 的 `std::function` 和 `std::bind` 如何解决异构类回调挑战?

Mary-Kate Olsen
发布: 2024-12-15 22:18:17
原创
621 人浏览过

How Can C  11's `std::function` and `std::bind` Solve Heterogeneous Class Callback Challenges?

在异构类之间传递回调

在 C 中,定义可以在不同类之间共享的回调可能会带来挑战。虽然提供静态成员函数并将指针传递给类实例是一种常见方法,但它限制了灵活性。以下是如何使用 C 11 的 std::functionstd::bind:

重构 EventHandler

重构而不是静态方法和实例指针

EventHandler 接受 std::function:

class EventHandler {
public:
    void addHandler(std::function<void(int)> callback) {
        // ... (as above)
    }
};
登录后复制
此函数接受一个接受整数参数且不返回任何内容的“函数对象”。

适配MyClass

修改

MyClassCallback 中删除 static 关键字并提供一个参数:

class MyClass {
public:
    void Callback(int x);
    // ...
};

MyClass::Callback(int x) {
    // ... (as above)
}
登录后复制

Callback 绑定到 EventHandler,使用std::bind:

handler->addHandler(std::bind(&MyClass::Callback, this, std::placeholders::_1));
登录后复制

_1 占位符表示单个参数。

独立函数和 Lambda 表达式

您可以直接在中使用独立函数

addHandler:

void freeStandingCallback(int x) {
    // ...
}

handler->addHandler(freeStandingCallback);
登录后复制
此外,C 11 lambda 表达式可以在

addHandler:

handler->addHandler([](int x) { std::cout << "x is " << x << '\n'; });
登录后复制

结论通过雇用

std::function

std::bind,回调可以在异构类之间无缝传递,提供灵活性和代码可重用性。

以上是C 11 的 `std::function` 和 `std::bind` 如何解决异构类回调挑战?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板