当前位置: 首页 > news >正文

STL --- 五. 函数对象 Function Objects

目录

1、函数对象的定义和作用

2、函数对象的分类和使用

3、std 常用的函数对象

4、函数对象的适配器

5、std 算法和函数对象区别


1、函数对象的定义和作用

STL(Standard Template Library)中的函数对象(Functor)是一种重载了函数调用运算符(operator())的类,可以像函数一样被调用。

函数对象可以在STL算法中被使用,作为函数参数传递给算法,可以实现一些常规函数无法实现的算法操作。

函数对象有以下作用:

(1)作为STL算法的参数,实现算法的灵活性和可扩展性。

(2)作为一种封装机制,可以将函数和状态信息打包在一起,提供更加灵活的函数调用方式。

(3)可以提供一些常规函数无法实现的算法操作,如状态保存,算法优化等。

(4)函数对象在STL中被广泛应用,如排序、查找、遍历、变换等。


2、函数对象的分类和使用

STL函数对象可以分为以下几类:

(1)一元函数对象:只有一个参数的函数对象,例如:negate、logical_not、plus、minus等。

(2)二元函数对象:有两个参数的函数对象,例如:plus、minus、multiplies、divides等。

(3)比较函数对象:用于比较两个值的函数对象,例如:less、greater、equal_to等。

(4)逻辑函数对象:用于逻辑运算的函数对象,例如:logical_and、logical_or、logical_not等。

(5)谓词函数对象:用于判断一个值是否满足某个条件的函数对象,例如:greater、less、equal_to等。

函数对象在STL中被广泛使用,例如在算法中作为参数传递,或者在容器中作为元素存储。

使用函数对象可以让代码更加简洁、清晰、可读性更强,提高代码的可维护性和可扩展性。

STL函数对象 示例:

#include <iostream>
#include <algorithm>
#include <vector>using namespace std;int main() {vector<int> v{5, 2, 8, 4, 9, 1};// 使用greater函数对象排序sort(v.begin(), v.end(), greater<int>());// 输出排序后的结果for (int i : v) {cout << i << " ";}cout << endl;// 使用lambda函数对象排序sort(v.begin(), v.end(), [](int a, int b) {return a < b;});// 输出排序后的结果for (int i : v) {cout << i << " ";}cout << endl;// 使用plus函数对象求和int sum = accumulate(v.begin(), v.end(), 0, plus<int>());// 输出求和结果cout << "Sum: " << sum << endl;return 0;
}

输出结果:

9 8 5 4 2 1 
1 2 4 5 8 9 
Sum: 29

在上面的示例中,我们使用了STL函数对象greater、lambda和plus。其中,greater用于排序,lambda用于排序和自定义比较函数,plus用于求和。这些函数对象都是STL中内置的,我们可以直接使用。

3、std 常用的函数对象

#include <>
1. plus:加法函数对象
2. minus:减法函数对象
3. multiplies:乘法函数对象
4. divides:除法函数对象
5. modulus:取模函数对象
6. negate:取反函数对象
7. equal_to:等于函数对象
8. not_equal_to:不等于函数对象
9. greater:大于函数对象
10. less:小于函数对象
11. greater_equal:大于等于函数对象
12. less_equal:小于等于函数对象
13. logical_and:逻辑与函数对象
14. logical_or:逻辑或函数对象
15. logical_not:逻辑非函数对象
16. unary_function:一元函数对象
17. binary_function:二元函数对象


4、函数对象的适配器

STL函数对象的适配器是一种用于修改现有函数对象的工具。

适配器允许您使用现有的函数对象来解决新问题或修改现有的函数对象以满足新的要求。

STL函数对象的适配器有以下几种:

(1)bind1st和bind2nd适配器: 这些适配器用于将一个二元函数对象转换为一个一元函数对象。bind1st适配器将第一个参数绑定到函数对象中,bind2nd适配器将第二个参数绑定到函数对象中。

(2)not1和not2适配器: 这些适配器用于将一个谓词函数对象转换为其否定形式。

(3)mem_fun和mem_fun_ref适配器: 这些适配器用于将一个成员函数转换为一个函数对象。

(4)compose1和compose2适配器: 这些适配器用于将两个函数对象合并为一个函数对象。

(5)ptr_fun适配器: 这个适配器用于将一个普通函数指针转换为一个函数对象。

这些适配器的使用可以大大增强STL函数对象的灵活性和可重用性。

5、std 算法和函数对象区别

STL中的算法和函数对象都是为了方便程序员使用而设计的,但它们的作用和使用方式有所不同。

(1)算法是一组预定义好的操作序列,可以用于对容器中的元素进行遍历、查找、排序等操作。STL中提供了很多常用的算法,如sort、find、replace等。这些算法都是通过迭代器来访问容器中的元素,所以它们可以适用于各种不同类型的容器。

(2)函数对象是一种可调用的对象,它可以像函数一样被调用。STL中的函数对象通常用于算法中,用来定义某些操作的行为。比如,STL中的sort算法可以接受一个函数对象作为参数,用来定义排序的方式。STL中提供了很多常用的函数对象,如less、greater、plus等。

总的来说,算法是对容器中的元素进行操作的一种方式,而函数对象则是用来定义操作行为的一种方式。算法和函数对象的结合可以实现更加灵活和高效的编程。

http://www.lryc.cn/news/90369.html

相关文章:

  • Java IO 流操作详解
  • Halcon 形状匹配参数详解
  • C++11强类型枚举
  • pytorch讲解(部分)
  • C++ 基本的7种数据类型和4种类型转换(C++复习向p3)
  • Scrum敏捷迭代规划和执行
  • 智警杯赛前学习1.1---excel基本操作
  • 【Android】Handle(一) 主要特点和用途
  • 40亿个QQ号,限制1G内存,如何去重?【已通过代码实现】
  • Talk预告 | 新加坡国立大学张傲:10%成本定制类 GPT-4 多模态大模型
  • 从C语言到C++_13(string的模拟实现)深浅拷贝+传统/现代写法
  • reduce()方法详解
  • C++虚假唤醒
  • 【AI】dragonGPT - 单机部署、极速便捷
  • Uuiapp使用生命周期,路由跳转传参
  • 定积分的计算(牛顿-莱布尼茨公式)习题
  • leak 记录今天的一个小题
  • 软考A计划-试题模拟含答案解析-卷二
  • 【C++】pthread
  • 2023年前端面试题汇总-浏览器原理
  • react介绍,react语法,react高级特性,react编程技巧
  • Locust接口性能测试
  • Python类的特殊方法(通过故事来学习)
  • Vue.js 中的父子组件通信方式
  • Python之并发编程二多进程理论
  • 纯干货:数据库连接耗时慢原因排查
  • 【OneNet】| stm32+esp8266-01s—— OneNet初体验 | 平台注册及设备创建 | demo使用
  • 解决win无法删除多层嵌套文件夹
  • 用Vue简单开发一个学习界面
  • Oracle数据库从入门到精通系列之五:数据文件