C++用模版封装一个万能函数

使用场景

有时候我们需要访问一些数据,并对数据进行一些操作,例如遍历一棵树,并对树的节点做一些操作。我们可以写一些DFS或者BFS遍历函数,并访问每一个节点做出相应动作, 如果我们有很多种操作行为,那么我们就需要写很多种这种遍历函数,聪明的你,可能已经想到,我可以将操作当做一个回调函数传入到遍历函数里面,这样就可以复用遍历代码。

对于单一的操作行为,这种方式是有效的,但是如果有很多种不同的操作行为,显然事先定义好的回调函数,可能不够用了。对于这种需求场景,我们可以使用访问者设计模式(Visit模式),该设计模式是典型的将数据和数据的操作分离的方法。不过,这里我并不想介绍访问者模式,而是介绍怎么用模版实现一个具有弹性的"回调函数",可以包装任意返回值,任意函数体,任意参数的可调用对象。

代码实现

闲话不说,直接看代码,核心是利用function和可变参数模版。

cpp 复制代码
#include <iostream>
#include <functional>

template<typename RetType>
class UniversalWrapper {
public:
	// 构造函数,接受一个函数和任意
	template<typename Func, typename... Args>
	UniversalWrapper(Func&& func, Args&&... args)
		: func_(std::bind(std::forward<Func>(func), std::forward<Args>(args)...)) {}

	// 仿函数
	RetType operator()() {
		return func_();
	}

private:
	std::function<RetType( )> func_;
};

int add(int a, int b) {
	return a + b;
}

std::string greet(const std::string& name, const std::string& greeting = "Hello") {
	return greeting + ", " + name + "!";
}

int main() {
	
	UniversalWrapper<int> wrapper1(add, 3, 5);  
	UniversalWrapper<std::string> wrapper2(greet, "Alice", "Hi"); 

	auto result1 = wrapper1();  
	auto result2 = wrapper2(); 

	std::cout << "Result1: " << result1 << std::endl; 
	std::cout << "Result2: " << result2 << std::endl; 

	return 0;
}

总结

这个实现通过模板参数 RetType 指定了返回值类型,并使用 std::function<RetType()> 存储绑定后的函数。你能够灵活地传递不同的函数和参数,并使用仿函数的形式调用它们。 这里你也可以把operator()设计成带参数的函数,只要在bind的时候留好place_holder就可以了。

相关推荐
CoovallyAIHub7 小时前
化工厂气体泄漏怎么用AI检测?30张图3D重建气体泄漏场景——美国国家实验室NeRF新研究
深度学习·算法·计算机视觉
肆忆_7 小时前
实战复盘:手写 C++ 虚拟机的高性能并行 GC (Thread Pool + Work Stealing)
c++
肆忆_7 小时前
虚函数进阶答疑:把上一篇博客评论区里最容易卡住的问题,一次追到底
c++
颜酱19 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
saltymilk1 天前
使用 C++ 模拟 ShaderLanguage 的 swizzle
c++·模板元编程
zone77391 天前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub1 天前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
兆子龙1 天前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法