89.STL-函数对象的使用(仿函数)

目录

1.什么是函数对象

2.仿函数示例

3.代码示例


1.什么是函数对象

函数对象是C++中的一种编程概念,也称为函数符或仿函数。其实就是重载"()"操作符,使得类对象可以像函数那样调用。

**分类:**假定某个类有一个重载的operator(),而且重载的operator()要求获取一个参数,我们就将这个类称为"一元仿函数";相反,如果重载的operator()要求获取两个参数,就将这个类称为"二元仿函数"。

**函数对象的作用主要是什么?**STL提供的算法往往都有两个版本,其中一个版本表现出最常用的某种运算,另⼀版本则允许用户通过template参数的形式来指定所要采取的策略。

2.仿函数示例

cpp 复制代码
#include <iostream>
using namespace std;

//定义自己的仿函数
class MyPrint {
public:
	int _num;
	MyPrint() {
		_num = 0;
	}

	void operator()(int n) {
		cout << n << endl;
		_num++;
	}
};

int main() {
	MyPrint my;
	my(10);
	my(20);
	my(30);
	cout << my._num << endl;

	return 0;
}

这是一个使用仿函数的简单示例。在这个例子中,MyPrint 是一个仿函数类,它定义了 operator(),使得类的实例可以像函数一样被调用。在 main 函数中,首先创建了 MyPrint 类的一个实例 my,然后通过调用 my(10)my(20)my(30) 来使用仿函数,最后输出 _num 的值。

简要解释每个部分:

  • MyPrint 类定义了一个整数成员变量 _num,并在构造函数中初始化为0。
  • operator() 是该类的重载函数,使得类的实例可以被调用。在这个例子中,调用仿函数时会输出传入的整数,并递增 _num 的值。
  • main 函数中,首先创建了 MyPrint 的实例 my。然后通过 my(10)my(20)my(30) 分别调用了仿函数。最后输出了 _num 的值,即仿函数被调用的次数。

3.代码示例

cpp 复制代码
#include <algorithm>
#include <vector>
#include <iostream>
using namespace std;

class MyComparator {
public:
    bool operator()(int a, int b) {
        return a > b;
    }
};

int main() {
    vector<int> numbers = { 3, 1, 4, 1, 5, 9, 2, 6 };

    sort(numbers.begin(), numbers.end(), MyComparator());

    for (int num : numbers) {
        cout << num << " ";
    }

    return 0;
}

这段代码演示了如何使用自定义的比较函数对象(仿函数)来对 C++ 标准库中的 std::sort 进行自定义排序。

具体解释:

  1. MyComparator 类定义:

    • MyComparator 是一个类,其中定义了一个重载的圆括号操作符 operator()。这使得 MyComparator 类的实例可以像函数一样被调用。
  2. std::vector 初始化:

    • 通过 std::vector<int> numbers = {3, 1, 4, 1, 5, 9, 2, 6}; 初始化了一个包含整数的向量。
  3. std::sort 调用:

    • std::sort 函数用于对容器进行排序。在这里,std::sort(numbers.begin(), numbers.end(), MyComparator()); 使用了自定义的比较函数 MyComparator 进行排序。这表示按照 MyComparator 的定义,即按照数字的逆序进行排序。
  4. 排序后输出:

    • 最后通过循环遍历输出排序后的结果。
    • for (int num : numbers):这是范围for循环的语法,它用于遍历容器中的每个元素。这里,numbers 是一个容器(std::vector<int> 类型),而 int num 则是循环过程中每个元素的临时变量。

这段代码最终会输出:9 6 5 4 3 2 1 1

写在最后:以上就是本篇文章的内容了,感谢你的阅读。如果感到有所收获的话可以给博主点一个赞哦。如果文章内容有遗漏或者错误的地方欢迎私信博主或者在评论区指出~

相关推荐
JAVA面经实录9174 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
王老师青少年编程5 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
周杰伦fans5 小时前
AutoCAD .NET 二次开发:深入理解 EntityJig 的工作原理与正确实现
开发语言·.net
叼烟扛炮5 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
样例过了就是过了7 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
Bat U7 小时前
JavaEE|多线程初阶(七)
java·开发语言
谭欣辰7 小时前
C++ 排列组合完整指南
开发语言·c++·算法
橙子也要努力变强8 小时前
信号捕捉底层机制-机理篇2
linux·服务器·c++
foundbug9998 小时前
自适应滤除直达波干扰的MATLAB实现
开发语言·算法·matlab