14. 3 内建函数对象
概念:
- STL内建了一些函数对象
分类: - 算术仿函数
- 关系仿函数
- 逻辑仿函数
用法: - 这些仿函数所产生的对象,用法和一般函数完全相同
- **使用内建函数对象,需要引入头文件functional **
14.3.1算数仿函数
功能描述:
- 实现四则运算
- 其中negate是一元运算,其他都是二元运算
仿函数原型: - template T plus //加法仿函数
- template T minus //减法仿函数
- template T multiplies //乘法仿函数
- template T divides //除法仿函数
- template T modulus //取模仿函数
- template T negate //取反仿函数(取负)
测试案例:
#include<iostream>
#include<vector>
#include<algorithm>
#include<string>
#include<time.h>
#include<functional> //内建函数对象头文件
using namespace std;
void test01()
{
//negate 一元仿函数 取反仿函数
negate<int> n;
cout <<"n(50)取反=" << n(50) << endl;
//Plus 二元仿函数(模板只写一个类型) 加法
plus<int> p;
cout << "两数之和:" << p(10, 30) << endl;
}
14.3.2 关系仿函数
功能描述:
- 实现关系对比
仿函数原型:
- template bool equal to //等于
- template bool not equal to //不等于
- template bool greater //大于
- template bool greater equal //大于等于
- template bool less //小于
- template bool less equal //小于等于
测试代码:
class Mysort
{
public:
bool operator()(int v1, int v2)
{
return v1 > v2;
}
};
void test01()
{
srand((int)time(0));//随机数种子
vector<int> v;
for (int i = 0; i < 5; i++)
v.push_back(rand() % 100);
for (vector<int>::iterator it = v.begin(); it != v.end(); it++)
cout << *it << " ";
cout << endl;
//greater<int>()内建大于v1>v2仿函数
//sort(v.begin(), v.end(),Mysort());
sort(v.begin(), v.end(), greater<int>()); //效果同上
for (vector<int>::iterator it = v.begin(); it != v.end(); it++)
cout << *it << " ";
cout << endl;
}
14.3.3 逻辑仿函数
功能描述:
- 实现逻辑运算
函数原型:
- template bool logical and //逻辑与
- template bool logical or //逻辑或
- template bool logical not //逻辑非
测试代码:
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;
vector<bool>v2;
//扩展空间
v2.resize(v.size());
//逻辑非 将v容器搬运到v2中,并执行逻辑非运行
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;
}