news 2026/5/11 18:48:21

STL - 函数对象

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
STL - 函数对象

STL - 函数对象

一、函数对象
1.概念
  • 重载函数调用操作符的类,其对象常成为函数对象
  • 函数对象使用重载的()时,行为类似函数调用,也叫仿函数

本质:函数对象(仿函数)是一个类,不是一个函数

2.函数对象使用

特点:

  • 函数对象在使用时,可以像普通函数那样调用,可以有参数,可以有返回值
  • 函数对象超出普通函数的概念,函数对象可以有自己的状态
  • 函数对象可以作为参数传递
//1 class MyAdd { public: int operator()(int v1, int v2) { return v1 + v2; } }; void test01() { //使用类创建对象,这里myAdd叫函数对象 MyAdd myAdd; cout << myAdd(7, 8) << endl;//15 //函数对象可以像函数一样调用 } //2 class MyPrint { public: MyPrint() { this->count = 0; } void operator()(string test) { cout << test << endl; this->count++; } int count;//记录状态,内部自己的状态 }; //有自己的状态 void test02() { MyPrint myPrint; myPrint("Hello! welcom to qingqingcaoyuan"); cout << "myPrint调用次数:"<<myPrint.count << endl; } //3.函数对象可以作为参数传递 void doPrint(MyPrint& mp, string test) { mp(test); } void test03() { MyPrint myPrint; doPrint(myPrint, "lanyy1"); }
二、谓词
1.概念
  • 返回bool类型的仿函数称为谓词
  • 如果operator()接受一个参数,那么叫做一元谓词
  • 如果operator()接受两个参数,那么叫做二元谓词
2.一元谓词
class GreaterFive { public: bool operator()(int val)//一元谓词 { return val > 6; } }; void test04() { vector<int>v; for (int i = 0; i < 10; i++) { v.push_back(i); } //查找容器中是否存在大于6的数字 //find_if,条件查找算法,返回的是一个迭代器 vector<int>::iterator it = find_if(v.begin(), v.end(), GreaterFive());//最后一个参数为匿名的函数对象,是我们要查找的条件 if (it == v.end()) { cout << "cannot find !" << endl; } else { cout << "find it ,the value is: " << *it << endl; } }

函数参数若是 pred 就代表这里需要填写一个谓词

3.二元谓词
class myCompare { public: bool operator()(int v1, int v2) { return v1 > v2; } }; void test05() { vector<int>v; v.push_back(7); v.push_back(8); v.push_back(3); v.push_back(6); v.push_back(5); sort(v.begin(), v.end());//默认升序排序 for (vector<int>::iterator it = v.begin(); it != v.end(); it++) { cout << *it << " "; } cout << endl; //改变排序规则,变为降序排序,使用函数对象(仿函数),将函数对象写在算法里面即可 sort(v.begin(), v.end(), myCompare());//类名不是函数对象,需要+(),才是一个对象(匿名对象) for (vector<int>::iterator it = v.begin(); it != v.end(); it++) { cout << *it << " "; } cout << endl; }
三、内建函数对象
1.基本概念

概念:STL内建了一些函数对象

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

用法:

仿函数所产生的对象,用法和一般函数完全相同

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

2.算术仿函数

实现四则运算;其中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> //取反仿函数

使用示例:

void test06() { //取反 一元仿函数 negate<int>n;//数据类型为int,数据名为n cout << n(7) << endl; //二元仿函数 plus<int>m;//默认认为传入的都是同种类型,只允许同类型相加 cout << m(7, 8) << endl; //其余运算只需要改变plus即可 }
3.关系仿函数

实现关系对比的操作,函数原型:

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> //小于等于

示例:

void test07() { //举例大于greater vector<int>v; v.push_back(7); v.push_back(8); v.push_back(6); v.push_back(9); v.push_back(5); for (vector<int>::iterator it = v.begin(); it != v.end(); it++) { cout << *it << " "; } cout << endl; //降序排序,默认排序是升序排序,想要降序排序,需要添加一个bool类型的谓词,默认是小于less //sort(v.begin(), v.end(), myCompare());//这是自己写的仿函数,其次可以使用编译器内建的仿函数 sort(v.begin(),v.end(),greater<int>());//greater<int>()是内建的仿函数 for (vector<int>::iterator it = v.begin(); it != v.end(); it++) { cout << *it << " "; } cout << endl; }
4.逻辑仿函数

实现逻辑运算,函数原型:

template<class T> bool logical_and<T> //逻辑与 template<class T> bool logical_or<T> //逻辑或 template<class T> bool logical_not<T> //逻辑非

示例:

void test08() { //主要举例逻辑非 vector<bool>v; v.push_back(true); v.push_back(false); 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());//一定要先指定空间大小 //使用特定函数进行转换放入 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; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/11 2:38:11

搜索二叉树的操作与实现(c Java)

07_二叉搜索树 二叉搜索树又叫二叉排序树&#xff0c;二叉查找树。 7.1 定义 在二叉树的基础上&#xff0c;增加了几个规则约束&#xff08;左小右大&#xff09;&#xff1a; 如果它的左子树不空&#xff0c;则左子树上所有的值均小于它的根节点的值若它的右子树不空&…

作者头像 李华
网站建设 2026/5/9 16:18:03

Linux操作系统之线程:线程互斥

前言 前文我们已经完成了对线程的简单封装&#xff0c;本文我们将开始对线程另外一个大阶段&#xff1a;线程的同步与互斥的学习。 本文将帮助大家了解线程互斥&#xff0c;锁的相关概念与知识。 注意&#xff0c;本文所用到的封装的thread&#xff0c;都是上一篇文章写好的…

作者头像 李华
网站建设 2026/5/10 11:09:34

AI原生应用中的上下文理解:常见误区与解决方案

AI原生应用中的上下文理解:常见误区与解决方案 元数据框架 标题:AI原生应用中的上下文理解:从理论误区到工程实践的系统性解决方案 关键词:上下文建模、AI原生应用、多模态上下文、动态语境感知、领域适配 摘要:本文系统性解析AI原生应用中上下文理解的核心挑战,从理论误…

作者头像 李华
网站建设 2026/5/10 3:16:04

把你的MCP Server部署到公网,让阿里云上的应用来访问和使用

一、前言 前前后后的给小落同学加了许多的MCP。 但是这些功能之前一直在我本地的小落同学上跑&#xff0c;部署在阿里云ECS上的小落同学因为买的ECS配置太低&#xff08;99元一年的2H2G特惠主机&#xff09;跑不动&#xff0c;这个周末在家没事做&#xff0c;想想是不是干脆用…

作者头像 李华
网站建设 2026/5/9 23:03:20

深入研究大数据领域 Hadoop 的 Oozie 工作流调度系统

深入研究大数据领域 Hadoop 的 Oozie 工作流调度系统 关键词:Oozie 工作流调度、Hadoop 生态、DAG 任务编排、工作流定义语言、分布式任务调度、ETL 流程管理、批处理作业协调 摘要:本文深入剖析 Hadoop 生态中的核心组件 Oozie,系统讲解其工作流调度原理、架构设计、核心功…

作者头像 李华