4.3、内建函数对象
4.3.1、内建函数对象的意义
1、 概念
- STL内建了一些函数对象
2、分类:
- 算术仿函数
- 关系仿函数
- 逻辑仿函数
3、用法:
- 这些仿函数所产生的对象,用法和一般函数完全相同
- 使用内建函数对象,需要引入头文件#include
4.3.2、算术仿函数
1、功能描述:
- 实现四则运算
- 其中negate是一元运算,其他都是二元运算
2、仿函数原型:
- teplate T plus //加法仿函数
- teplate T minus //减法仿函数
- teplate T multiplies //乘法仿函数
- teplate T divides //除法仿函数
- teplate T modulus //取模仿函数
- teplate T negate //取反仿函数
3、代码
#include<iostream>
#include<vector>
#include<functional>
using namespace std;
//内建函数对象 算术仿函数
//negate 一元仿函数 取反仿函数
void test01()
{
negate<int>n;
cout << n(50) << endl;
}
//plus 二元仿函数 加法
void test02()
{
plus<int>p;
cout << p(10, 20) << endl;
}
int main()
{
test01();
test02();
system("pause");
return 0;
}
4、总结:
- 使用内建函数对象时,需要引入头文件functional
5、运算结果
4.3.3、关系仿函数
1、功能描述:
- 实现关系对比
2、仿函数原型:
- teplate bool equal_to //等于
- teplate bool not_equal_to //不等于
- teplate bool greater //大于
- teplate bool greater_equal //大于等于
- teplate bool less //小于
- teplate bool less_equal //小于等于
3、代码
#include<iostream>
#include<vector>
#include<functional>
#include<algorithm>
using namespace std;
//内建函数对象 关系仿函数
//greater 大于
class MyCompare
{
public:
bool operator ()(int v1, int v2)
{
return v1 > v2;
}
};
void test01()
{
vector<int>v;
v.push_back(10);
v.push_back(30);
v.push_back(40);
v.push_back(20);
v.push_back(50);
for (vector<int>::iterator it = v.begin(); it != v.end(); it++)
{
cout << *it << " ";
}
cout << endl;
//降序
//sort(v.begin(), v.end(), MyCompare());
//greater<int>() 内建函数对象
sort(v.begin(), v.end(), greater<int>());
for (vector<int>::iterator it = v.begin(); it != v.end(); it++)
{
cout << *it << " ";
}
cout << endl;
}
int main()
{
test01();
system("pause");
return 0;
}
4、总结:
- 关系仿函数中最常用的就是greater<>()大于
5、运行结果
4.3.3、逻辑仿函数
1、功能描述:
- 实现逻辑运算
2、仿函数原型:
- teplate bool logical_and //逻辑与
- teplate bool logical_or //逻辑或
- teplate bool logical_not //逻辑非
3、代码
#include<iostream>
#include<vector>
#include<functional>
#include<algorithm>
using namespace std;
//内建函数对象 逻辑仿函数
//logical 逻辑非
class MyCompare
{
public:
bool operator ()(int v1, int v2)
{
return v1 > v2;
}
};
void test01()
{
vector<bool>v;
v.push_back(true);
v.push_back(false);
v.push_back(true);
v.push_back(false);
for (vector<bool>::iterator it = v.begin(); it != v.end(); it++)
{
cout << *it << " ";
}
cout << endl;
//利用逻辑非 将容器v搬运到v2中,并进行取反操作
vector<bool>v2;
v2.resize(v.size());
transform(v.begin(), v.end(),v2.begin(), logical_not<bool>());
for (vector<bool>::iterator it = v2.begin(); it != v2.end(); it++)
{
cout << *it << " ";
}
cout << endl;
}
int main()
{
test01();
system("pause");
return 0;
}
4、总结:
- 逻辑仿函数实际应用较少,了解即可
5、运行结果