前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C++仿函数(函数对象)

C++仿函数(函数对象)

作者头像
半生瓜的blog
发布2023-05-12 21:43:13
2960
发布2023-05-12 21:43:13
举报
文章被收录于专栏:半生瓜のblog半生瓜のblog

仿函数(函数对象)

研究set/multiset容器的排序原理。

当我们构造一个存放int类型的set容器时

代码语言:javascript
复制
set<int> s1;

系统会自动帮我们设定并调用一个函数,自动调用头文件functional中的仿函数(一个类中重载了()实现了对比的操作,从而完成了排序)。

代码语言:javascript
复制
set<int,less<int>> s1;

less函数对象实现比较,为排序提供依据。(升序) greater(降序)

functional中,如图

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-n2y3WzyW-1632820236223)(01仿函数functor.assets/image-20210928153035870.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-n2y3WzyW-1632820236223)(01仿函数functor.assets/image-20210928153035870.png)]

手动实现:

代码语言:javascript
复制
#include<iostream>
#include<set>
using namespace std;
class Student
{
public:
	Student(int _age):age(_age)
	{

	}
	int getAge()const
	{
		return age;
	}
	bool operator < (const Student& right) const {
		return this->age < right.age;
	}

	bool operator > (const Student& right) const {
		return this->age > right.age;
	}

	~Student() { } 
private:
	int age;
};

int main(void)
{
	set<Student,greater<Student>> setStu;
	setStu.insert(19);
	setStu.insert(20);
	setStu.insert(18);
	

	for (set<Student>::iterator it = setStu.begin(); it != setStu.end(); it++)
	{
		cout << it->getAge()<< endl;
	}
	
	return 0;
}

如果一个类将()运算符重载为成员函数,这个类就称为函数对象类,这个类的对象就是函数对象。函数对象是一个对象,但是使用的形式看起来像函数调用,实际上也执行了函数调用,因而得名。——C++函数对象详解

实现自己的less(greater)达到效果:

代码语言:javascript
复制
class FuncStudent
{
public:
	bool operator()(const Student& left, const Student& right)const
	{
		return left.getAge() > right.getAge();
	}
};
int main(void)
{
	set<Student,FuncStudent> setStu;
	Student s1(12);
	Student s2(13);
	setStu.insert(s1);
	setStu.insert(s2);
	
	for (set<Student,FuncStudent>::iterator it = setStu.begin(); it != setStu.end(); it++)
	{
		cout << it->getAge()<< endl;
	}
	
	return 0;
}

仿函数(函数对象)概念

  1. 尽管函数指针被广泛用于实现函数回调,但C++还提供了一个重要的实现回调函数的方法,那就是函数对象。回调函数解释——回调函数
  2. functor,翻译成函数对象,伪函数,它是是重载了“()”操作符的普通类对象。从语法上讲,它与普通函数行为类似。
  3. functional头文件中包含的 greater<>与less<>就是函数对象。

set/setmulti容器就是调用函数对象的operator()方法去比较两个值的大小,从而实现的排序。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-09-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 仿函数(函数对象)
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档