C++(十七)仿函数

简介: ### Functor 仿函数简介Functor(仿函数)是一种通过在类中实现 `operator()` 使其行为像函数的对象。这种方式可以让类拥有更多可定制的功能,同时保持函数般的简洁调用方式。下面展示了如何定义和使用一个计算幂运算的仿函数类,并通过示例说明了其在 `std::sort` 中的优势与灵活性。

Functor 对象模拟函数

把类对象,像函数名一样使用。

仿函数(functor),就是使一个类的使用看上去像一个函数。其实现就是类中实现
一个 operator(),这个类就有了类似函数的行为,就是一个仿函数类了。

operator() 语法格式

class 类名
{
    返值类型 operator()(参数类型)
        函数体
}
#include <iostream>
#include <math.h>
using namespace std;

class Pow
{
public:
    //仿函数
    double operator()(double a, int b){
        double result = 1;
        for(int i=0;i<b;i++){
            result *= a;
        }
        return result;
    }

};
int main()
{
    cout<<pow(5,2)<<endl;
    Pow mypow;
    cout<<mypow(5,2)<<endl;
    return 0;
}

functor 的优势

functor 的优势在于,是对象形式,可以携带更多的的信息,用于作出判断。
比如,我们可以在对象初始化的时候,传入参数来决定状态,而不用去修改原代码。

functor使用示例

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

//局限性较大
bool myCompare(int a, int b){
    return a < b;
}

//仿函数,可以携带更多参数
class Compare{
public:
    Compare(bool flag=true):flag(flag){}
    bool operator()(int a, int b){
        if (flag==true)
            return a < b;
        else
            return a > b;
    }
private:
    bool flag;
};

int main(){
    int arr[] = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5};

    vector<int> vi(arr, arr+11);
    sort(vi.begin(), vi.end(), Compare(false));

//c98的写法
//    vector<int>::iterator itr;
//    for(itr=vi.begin();itr!=vi.end();++itr){
//        cout<<*itr<<" ";
//    }

    //c++11的写法
    for(auto itr=vi.begin();itr!=vi.end();++itr){
        cout<<*itr<<" ";
    }

    //c++17的写法
//    for(auto i : vi){
//        cout<<i<<" ";
//    }

    return 0;
}
相关文章
|
6月前
|
C++ 容器
【C++】仿函数在模板中的应用——【默认模板实参】详解(n)
【C++】仿函数在模板中的应用——【默认模板实参】详解(n)
|
4月前
|
存储 算法 Java
【C++】优先级队列priority_queue模拟实现&&仿函数
【C++】优先级队列priority_queue模拟实现&&仿函数
38 1
|
5月前
|
算法 安全 编译器
【C++进阶】模板进阶与仿函数:C++编程中的泛型与函数式编程思想
【C++进阶】模板进阶与仿函数:C++编程中的泛型与函数式编程思想
49 1
|
5月前
|
C++
C++函数对象(仿函数)
C++函数对象(仿函数)
|
6月前
|
算法 C语言 C++
从C语言到C++_20(仿函数+优先级队列priority_queue的模拟实现+反向迭代器)(上)
从C语言到C++_20(仿函数+优先级队列priority_queue的模拟实现+反向迭代器)
49 1
|
6月前
|
算法 C语言 C++
从C语言到C++_20(仿函数+优先级队列priority_queue的模拟实现+反向迭代器)(下)
从C语言到C++_20(仿函数+优先级队列priority_queue的模拟实现+反向迭代器)
26 0
从C语言到C++_20(仿函数+优先级队列priority_queue的模拟实现+反向迭代器)(下)
|
算法 测试技术 C++
C++:优先级队列模拟实现和仿函数的概念使用
C++:优先级队列模拟实现和仿函数的概念使用
|
6月前
|
编译器 C语言 C++
【C++进阶(七)】仿函数深度剖析&模板进阶讲解
【C++进阶(七)】仿函数深度剖析&模板进阶讲解
|
存储 算法 安全
04-📝C++核心语法|面向对象2【友元、内部类与局部类、强化训练(数组类封装)、运算符重载、仿函数、模板、类型转换、 C++标准、错误&&异常、智能指针】
复习`C++核心语法`,且适当进行汇编探索底层实现原理,进一步夯实基础,为以后的`底层开发`、`音视频开发`、`跨平台开发`、`算法`等方向的进一步学习埋下伏笔。
04-📝C++核心语法|面向对象2【友元、内部类与局部类、强化训练(数组类封装)、运算符重载、仿函数、模板、类型转换、 C++标准、错误&&异常、智能指针】
|
6月前
|
C++
C++ operator关键字的使用(重载运算符、仿函数、类型转换操作符)
C++ operator关键字的使用(重载运算符、仿函数、类型转换操作符)
87 0