答案:通过std::function和std::vector实现多播委托,支持函数指针、lambda等可调用对象的注册与调用,具备类型安全和简洁语法。1. 使用模板类MulticastDelegate<Args...>存储回调列表;2. 重载+=添加、-=移除回调,()触发所有回调;3. 示例中定义EventHandler处理EventArgs参数;4. 注意lambda无法直接移除、性能及线程安全等问题。该方案轻量高效,适用于嵌入式或游戏开发中的事件系统。

在C++中实现类似C#的多播委托(Multicast Delegate)和事件模型,核心目标是支持一个或多个函数监听某个事件,并在事件触发时依次调用这些函数。虽然C++没有原生的委托机制,但借助std::function和std::vector,我们可以构建一个轻量、类型安全且易于使用的多播委托系统。
多播委托本质上是一个可调用对象列表。当委托被“调用”时,它会遍历所有注册的回调并执行它们。我们希望这个系统支持:
下面是一个简洁的多播委托模板类实现:
#include <vector>
#include <functional>
#include <algorithm>
<p>template <typename... Args>
class MulticastDelegate {
private:
using Callback = std::function<void(Args...)>;
std::vector<Callback> callbacks;</p><p>public:
// 添加一个回调
void operator+=(const Callback& func) {
callbacks.push_back(func);
}</p><pre class='brush:php;toolbar:false;'>// 移除一个回调
void operator-=(const Callback& func) {
callbacks.erase(
std::remove_if(callbacks.begin(), callbacks.end(),
[&func](const Callback& cb) {
return cb.target_type() == func.target_type() &&
&*cb.template target<void(*)(Args...)>() ==
&*func.template target<void(*)(Args...)>();
}),
callbacks.end());
}
// 触发所有回调
void operator()(Args... args) const {
for (const auto& cb : callbacks) {
cb(args...);
}
}
// 清空所有回调
void clear() {
callbacks.clear();
}
bool empty() const {
return callbacks.empty();
}};
立即学习“C++免费学习笔记(深入)”;
以下是一个简单的使用示例,模拟C#风格的事件通知:
#include <iostream>
<p>// 定义事件参数
struct EventArgs {
int value;
EventArgs(int v) : value(v) {}
};</p><p>// 声明一个多播委托,接受一个EventArgs
using EventHandler = MulticastDelegate<const EventArgs&>;</p><p>// 几个事件处理器
void Handler1(const EventArgs& e) {
std::cout << "Handler1: received " << e.value << "\n";
}</p><p>void Handler2(const EventArgs& e) {
std::cout << "Handler2: processing " << e.value << "\n";
}</p><p>int main() {
EventHandler onValueChanged;</p><pre class='brush:php;toolbar:false;'>// 绑定事件
onValueChanged += Handler1;
onValueChanged += Handler2;
// 触发事件
EventArgs args(42);
onValueChanged(args); // 两个处理器都会被调用
// 移除其中一个
onValueChanged -= Handler1;
std::cout << "--- After removing Handler1 ---\n";
onValueChanged(args);
return 0;}
上述实现适用于大多数简单场景,但有几点需要注意:
-=正确移除。建议对lambda绑定使用std::function变量保存引用以便后续移除。std::list存储。基本上就这些。这个实现足够轻便,能在嵌入式或游戏开发中替代复杂的信号槽系统,同时保留了C#事件模型的核心语义。
以上就是c++++如何实现一个简单的多播委托(Multicast Delegate)_c++ C#事件模型的C++实现的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号