设计模式 策略模式2 c++11
2024-10-20 01:33:57
根据需求的不同 选择不同的策略算法
之前是保存的各种策略类的指针
这里直接使用 function bind 选择对应的算法
代码
// 005.cpp: 定义控制台应用程序的入口点。
// #include "stdafx.h"
#include <functional>
#include <iostream> using namespace std; int MyAdd(int a, int b) { return a + b; } class MyMinus {
public:
int operator()(int a, int b) {
return a - b;
}
}; class binary_operators {
public:
typedef std::function<int(int, int)> FUNC;
binary_operators(FUNC f,int a, int b) :func_(f),left(a), right(b),result() {}
int GetResult() { return func_(left, right); }
private:
std::function<int(int, int)> func_;
int left;
int right;
int result;
}; int main()
{
binary_operators addOperation(std::function<int(int, int)>(MyAdd),,);
binary_operators minusOperation(std::function<int(int, int)>(MyMinus()), , ); std::cout << "addOperation(1,2) result: " << addOperation.GetResult() << std::endl;
std::cout << "minusOperation(5,7) result: " << minusOperation.GetResult() << std::endl;
return ;
}
最新文章
- .net 刷新页面防止表单二次提交
- Android基础总结(二)
- angularJS 2.0 开发的简单dome
- 5种IO模型
- 使用https时,网站一些内容不能正常显示的问题
- 关于搭建haddoop分布式系统的全部过程复习
- 电脑突然死机,系统日志记录事件ID=6008
- C#嵌套类型
- jQuery插件综合应用(三)发布文章页面
- delphi算法
- Thinkphp3.2———配置模块
- C#更改操作系统时间
- table中的一些另类标签
- 高速排序,归并排序,堆排序python实现
- 【JDK】JDK模块化(1)-为什么要模块化
- PMS构造函数以及apk如何扫描
- 最少步数(bfs)
- 使用padding值控制控件的隐藏与显示
- 使用vue脚手架(vue-cli)快速搭建项目
- 一个页面从输入 URL 到页面加载显示完成,这个过程中都发生了什么?