STL中的二元函数binary_function

时间:2021-09-11 04:19:24

      

       函数对象是重载了operator()的类的一个实例,operator()是函数调用运算符。

标准C++库根据operator()参数个数加以划分,主要有以下几种类型:

       1  发生器:一种没有参数且返回一个任意类型值的函数对象,例如随机数发生器。

       2  一元函数:一种只有一个任意类型的参数,且返回一个可能不同类型值的函数对象。

       3  二元函数:一种有两个任意类型的参数,且返回一个可能不同类型值的函数对象。

       4  一元判定函数:返回bool型值的一元函数。

       5  二元判定函数:返回bool型值的二元函数。


     样例

     //1   一个自定义类型

     

#include <string>
#include <iostream>
using namespace std;

class Student
{
public:
Student(void);
~Student(void);

public:
string _stuName;
float _stuScore;

public:
Student(string stuName,float stuScore)
{
_stuName=stuName;
_stuScore=stuScore;
}

//布尔运算符重载
bool operator <(const Student& stu)
{
return _stuScore<stu._stuScore;
}

//()运算符重载
void operator()(const Student& stu)
{
cout<<stu._stuName<<" "<<stu._stuScore<<endl;
}


};
 

//2  重载系统二元函数

#pragma once
#include <functional>
using namespace std;


//不能有构造函数
template <class inPara , class outPara>
class binary_sort:public binary_function<inPara,outPara,bool>
{
public:
bool operator()(inPara in1,outPara in2)
{
return in1<in2;
}
};

//3  使用样例

 

#include "stdafx.h"

#include <string>
#include <vector>
#include <iostream>
#include <functional>
#include <algorithm>

#include "Student.h"
#include "binary_sort.h"


int _tmain(int argc, _TCHAR* argv[])
{

vector<Student>v;

//向量赋值
Student s1("11111",67);
v.push_back(s1);

Student s2("2222",45);
v.push_back(s2);

Student s3("33333",78);
v.push_back(s3);

//利用函数对象,输出各个元素
cout<<"before sort()"<<endl;
for_each(v.begin(),v.end(),Student());


cout<<"after sort()"<<endl;
//利用二元判定函数进行排序
sort(v.begin(),v.end(),binary_sort<Student&,Student&>());

for_each(v.begin(),v.end(),Student());


getchar();
return 0;
}