函数对象

函数对象

函数对象是内部重载了函数调用运算符“()”的类实例化出来的对象,但是使用过程中很像一个函数,所以也称为仿函数。

class Add
{
public:
    int operator()(int v1, int v2)
    {
        return v1 + v2;
    }
};

//函数对象在使用的时候和普通函数一样,拥有参数和返回值
void test01()
{
    Add add;
    cout << add(1, 2) << endl; //3
}

//函数对象超出普通函数的概念,函数对象可以有自己的状态
class Print
{
public:
    void operator()(string test)
    {
        cout << test << endl;
        count++;
    }
    //统计函数被调用了多少次
    int count = 0;
};

void test02()
{
    Print print;
    print("hello world");
    print("hello world");
    print("hello world");
    print("hello world");
    cout << "函数被调用了" << print.count << "次" << endl;  //4次
}

//函数对象可以作为参数传递
void doPrint(Print &mp, string test)
{
    mp(test);
}

void test03()
{
    Print print;
    doPrint(print, "hello cpp");
}
  • 函数对象在使用的时候和普通函数一样,拥有参数和返回值;
  • 函数对象超出普通函数的概念,函数对象可以有自己的状态;
  • 函数对象可以作为参数传递。

谓词

谓词是返回值类型为bool的函数对象。如果operator()接收一个参数,叫一元谓词;如果operator()接收两个参数,叫二元谓词。

一元谓词

//一元谓词
class GreaterFive
{
public:
    bool operator()(int val)
    {
        return val > 5;
    }
};

void test01()
{
    vector<int> v;
    for (int i = 0; i < 10; i++)
    {
        v.push_back(i + 1);
    }
          
        //fand_if,找到返回该元素的迭代器,否则返回结束迭代器
    vector<int>::iterator pos = find_if(v.begin(), v.end(), GreaterFive());
    if (pos == v.end())
    {
        cout << "没有找到大于5的数字" << endl;
    }
    else
    {
        cout << "第一个大于5的数字为:" << *pos << endl;
    }
}

这个案例里面用到了一个标准算法find_if,它会按条件查找满足要求的元素。这里说的“要求”就是仿函数的功能。在本例中,仿函数是判断一个数字是否比5大,如果大于5,则返回真,否则返回假。此仿函数作为参数传递给find_if,就可以遍历查找比五大的数字了。如果查到了,返回该元素所在的迭代器,否则返回end迭代器。

二元谓词

//二元谓词
class Compare
{
public:
    bool operator()(int val1, int val2)
    {
        return val1 > val2;
    }
};

void printVector(const vector<int> &v)
{
    for (vector<int>::const_iterator it = v.begin(); it != v.end(); it++)
    {
        cout << *it << " ";
    }
    cout << endl;
}

void test01()
{
    vector<int> v;
    v.push_back(2);
    v.push_back(3);
    v.push_back(5);
    v.push_back(4);
    v.push_back(1);

    sort(v.begin(), v.end()); //从小到大排序
    printVector(v); //1 2 3 4 5

    //使用函数对象改算法策略为降序排列
    sort(v.begin(), v.end(), Compare());
    cout << "降序排列" << endl;
    printVector(v);// 5 4 3 2 1
}

标准算法sort默认情况下是按声升序排列的,但是我们可以通过二元谓词来改变它的排序策略为降序。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 函数和对象 1、函数 1.1 函数概述 函数对于任何一门语言来说都是核心的概念。通过函数可以封装任意多条语句,而且...
    道无虚阅读 4,665评论 0 5
  • C++ lambda表达式与函数对象 lambda表达式是C++11中引入的一项新技术,利用lambda表达式可以...
    小白将阅读 85,427评论 15 117
  • 数组 所谓数组 Array 就是将多个元素(通常是一个类型)按一定顺序排列放到一个集合中,那么这个集合就称为数组 ...
    甄子健阅读 295评论 0 2
  • 重载函数调用运算符 如果类重载了函数调用运算符,则我们可以像使用函数一样使用该类的对象,因为这样的类同时也能存储状...
    土豆吞噬者阅读 840评论 0 0
  • 表情是什么,我认为表情就是表现出来的情绪。表情可以传达很多信息。高兴了当然就笑了,难过就哭了。两者是相互影响密不可...
    Persistenc_6aea阅读 126,143评论 2 7