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 
#include 
#include 

using namespace std;

int main() {
    vector v{5, 2, 8, 4, 9, 1};

    // 使用greater函数对象排序
    sort(v.begin(), v.end(), greater());

    // 输出排序后的结果
    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());

    // 输出求和结果
    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等。

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

你可能感兴趣的:(STL,c++,开发语言)