c++内建函数对象

使用内建仿函数需要引入头文件#include <functional>

分类:
算术仿函数
关系仿函数
逻辑仿函数

这三种仿函数底层struct定义eg:
在这里插入图片描述

1.算术仿函数

//除了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> //取反仿函数

2.关系仿函数

//都为二元运算
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> //小于等于

3.逻辑仿函数

//not为一元运算,其余为二元运算
template<class T> bool logical_and<T> //逻辑与
template<class T> bool logical_or<T> //逻辑或
template<class T> bool logical_not<T> //逻辑非

eg:

#include <functional>
#include <iostream>
#include <vector>
#include <algorithm>//算法库

using namespace std;

//算术仿函数
void test01() {
	//加法
	plus<int> p;
	cout << p(20, 30) << endl; //输出50
	//除法,前除后
	divides<int> d;
	cout << d(20, 10) << endl; //输出2
	//取反
	negate<int> n;
	cout << n(50) << endl; //输出-50
}
//关系仿函数
void test02() {
	//比大小
	greater<int> g;
	cout << g(20, 30) << endl; //输出0,即false

	//使用greater对vector容器排序
	vector<int> v;
	for (int i = 0; i < 5; i++)
	{
		//随机生成
		v.push_back(rand() % 10);
	}
	//greater<int>()匿名对象
	sort(v.begin(), v.end(), greater<int>());

	//遍历
	for (vector<int>::iterator it = v.begin(); it != v.end(); it++)
	{
		cout << *it << " ";
	}
	cout << endl;
}

//逻辑仿函数,不常用
void test03() {
	//逻辑非
	logical_not<bool> ln;
	cout << ln(false) << endl;//输出1

	//逻辑或
	logical_or<bool> lo;
	cout << lo(false, false) << endl;//输出0
}
int main() {
	test01();
	test02();
	test03();
}

运行结果:

50
2
-50
0
9 7 4 1 0
1
0
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值