目录
内建函数对象意义
概念:
- STL 内建了一些函数对象
分类:
- 算术仿函数
- 关系仿函数
- 逻辑仿函数
作用:
- 仿函数产生对象用法和普通函数相同
- 使用内建函数对象,需要引入头文件 <functional>
- 主要是给内置数据类型使用的,自定义数据类型还是要用谓词
算术仿函数
功能:
- 实现四则运算
- 其中 negate(取反) 是一元运算(变成相反数),其他都是二元运算
仿函数原型:
// 加法仿函数 template<class T> T plus<T> // 减法仿函数 template<class T> T minus<T> // 乘法仿函数 template<class T> T multiplies<T> // 除法仿函数 template<class T> T divides<T> // 取模仿函数 template<class T> T modulus<T> // 取反仿函数 template<class T> T negate<T>
加法仿函数和取反仿函数测试代码:
#include<iostream>
using namespace std;
#include<functional>
// 内建仿函数
// negate 一元仿函数,取反仿函数
void test01() {
negate<int>n;
cout << n(100) << endl; // -100
}
// plus 二元仿函数 加法
void test02() {
plus<int>p;
cout << p(10, 20) << endl; // 30
}
int main() {
test01();
test02();
system("pause");
return 0;
}
运行结果:
加、减、乘、除、取模 操作类似,注意要包含 <functional> 头文件
关系仿函数
功能:
- 实现关系对比
仿函数原型:
// 等于 template<class T> bool equal_to<T> // 不等于 template<class T> bool not_equal_to<T> // 大于 template<class T> bool greater<T> // 大于等于 template<class T> bool greater_equal<T> // 小于 template<class T> bool less<T> // 小于等于 template<class T> bool less_equal<T>
常用的大于仿函数
测试代码:
#include<iostream>
using namespace std;
#include<vector>
#include<algorithm>
#include<functional>
void PrintVector(const vector<int>& v) {
for (vector<int>::const_iterator it = v.begin(); it != v.end(); ++it) {
cout << *it << " ";
}
cout << endl;
}
void test() {
vector<int>v;
v.push_back(10);
v.push_back(50);
v.push_back(20);
v.push_back(40);
v.push_back(30);
// 升序
sort(v.begin(), v.end());
PrintVector(v);
// 降序
sort(v.begin(), v.end(), greater<int>());
PrintVector(v);
}
int main() {
test();
system("pause");
return 0;
}
运行结果:
10 20 30 40 50
50 40 30 20 10
请按任意键继续. . .
sort 中默认就是 less
逻辑仿函数
功能:
- 实现逻辑运算
仿函数原型:
// 逻辑与 template<class T> bool logical_and<T> // 逻辑或 template<class T> bool logical_or<T> // 逻辑非 template<class T> bool logical_not<T>
实际用的不多
逻辑非的测试代码:
#include<iostream>
using namespace std;
#include<vector>
#include<algorithm>
#include<functional>
// logical_not
void PrintVector(const vector<bool>& v) {
for (vector<bool>::const_iterator it = v.begin(); it != v.end(); ++it) {
cout << *it << " ";
}
cout << endl;
}
void test() {
vector<bool>v;
v.push_back(true);
v.push_back(false);
v.push_back(true);
v.push_back(false);
v.push_back(true);
PrintVector(v); // 1 0 1 0 1
// 运用逻辑非 将容器 v 搬运到 容器 v2 中,执行取反的操作
vector<bool>v2;
// 给 v2 初始化 v1 空间大小
v2.resize(v.size());
// 搬运算法
transform(v.begin(), v.end(), v2.begin(), logical_not<bool>());
// 输出
PrintVector(v2); // 0 1 0 1 0
}
int main() {
test();
system("pause");
return 0;
}
运行结果: