C++中通过模板结合函数对象或lambda实现策略模式,编译期绑定策略以消除运行时开销。定义如Ascending、Descending等函数对象并重载operator(),再通过模板参数传入Sorter类,实现不同排序逻辑。例如Sorter<Ascending>在编译期生成升序排序代码,避免虚函数调用。C++11后可直接传入lambda,如按奇偶性排序的闭包,并利用decltype推导类型。为简化使用,可用using定义类型别名,如using AscendingSorter = Sorter<Ascending>,提升可读性。该方式具备高性能、类型安全和灵活性,但每种策略组合会实例化独立模板,可能增大代码体积,且要求统一调用接口。若需运行时切换策略,则需改用std::function或虚函数机制。因此,模板策略模式适用于编译期确定行为、追求效率的场景,是泛型编程中实现高内聚低耦合的经典实践。

在C++中,可以通过模板结合函数对象(仿函数)或lambda表达式来实现策略选择模式,这种方式在编译期完成策略绑定,避免运行时多态的开销,同时保持代码的灵活性和可扩展性。
定义多个结构体或类作为具体策略,每个策略实现相同的调用接口(如重载
operator()
例如,实现一个排序器,支持不同比较策略:
struct Ascending {
bool operator()(int a, int b) const {
return a < b;
}
};
struct Descending {
bool operator()(int a, int b) const {
return a > b;
}
};
template<typename Strategy>
class Sorter {
Strategy strategy;
public:
void sort(std::vector<int>& data) {
std::sort(data.begin(), data.end(), strategy);
}
};
使用方式:
立即学习“C++免费学习笔记(深入)”;
std::vector<int> nums = {3, 1, 4, 1, 5};
Sorter<Ascending> asc_sorter;
asc_sorter.sort(nums); // 升序排列
Sorter<Descending> desc_sorter;
desc_sorter.sort(nums); // 降序排列
</font>C++11以后,lambda也可作为模板策略传入,适合简单逻辑。
例如:
auto custom_cmp = [](int a, int b) {
return (a % 2) < (b % 2); // 按奇偶性排序
};
Sorter<decltype(custom_cmp)> custom_sorter;
custom_sorter.sort(nums);
为简化使用,可用
using
using AscendingSorter = Sorter<Ascending>; using DescendingSorter = Sorter<Descending>;
这样用户无需显式写模板参数,直接声明即可:
AscendingSorter sorter; sorter.sort(data);
优势:
注意:
以上就是C++如何使用模板实现策略选择模式的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号