C++:binary_function与unary_function使用详解

本文深入探讨了C++中的一元函数对象(unary_function)和二元函数对象(binary_function)的使用方法,包括它们的原型、如何通过继承基类来重写operator()以实现特定功能,以及实际应用示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


一   unary_function一元函数使用

原型:
  1. template <class Arg, class Result> struct unary_function;
  2. template <class Arg, class Result> // 1个参数,一个返回值
  3. struct unary_function {
  4. typedef Arg argument_type;
  5. typedef Result result_type;
  6. };



          在C++98版本中,这个使用的很频繁,后来在C++11中就少见,在官网网站上看被注明是过时的。但是不能就这么否定它的存在,高效的使用,可以为程  序添彩不少。
          这是一个标准的一元函数对象基类,一般的函数对象是类成员operator()被定义 的实例,这个成员函数允许对象被用于作为正则函数相同语法调用,因此当使用泛型函数类型时,它的类型作为模板参数。
          作为一元函数对象,operator() 成员函数带一个简单参数。
               unary_function 仅仅是一个基类,特殊的函数对象会继承于它。它自身没有operator() 成员函数。
                
               头文件: 
          #include <functional>       // std::unary_function 
          简单写一个判断是否为负数的例子:
          
  1. struct TJudegNagetive: public std::unary_function(int,bool){
  2. bool operator(int num){
  3. return num < 0;
  4. }
  5. }
  6. int main(){
  7. TJudegNagetive oJudeNagetive;
  8. bool isNagetive = oJudeNagetive(1);
  9. std::cout<<" 是负数 ?:"<<isNagetive<<endl;
  10. return 0;
  11. }
          
         

二   binary_function二元函数使用

         原型:
       
  1. template <class Arg1, class Arg2, class Result> struct binary_function;
  2. template <class Arg1, class Arg2, class Result>
  3. struct binary_function {
  4. typedef Arg1 first_argument_type;
  5. typedef Arg2 second_argument_type;
  6. typedef Result result_type;
  7. };
     
这是一个标准的二元函数对象基类,一般的函数对象是类成员operator()被定义 的实例,这个成员函数允许对象被用于作为正则函数相同语法调用,因此当使用泛型函数类型时,它的类型作为模板参数。
   作为二元函数对象,operator() 成员函数带两个简单参数。
    binary_function仅仅是一个基类,特殊的函数对象会继承于它。它自身没有operator() 成员函数。
  头文件: 
          #include <functional>       // std::unary_function 
举个栗子:
比较大小值,返回最大数:
  1. struct TCompareNumSize: public std::unary_function(int,int,int){
  2. int operator(int num1, int num2){
  3. return num1< num2 ? num2:num1;
  4. }
  5. }
  6. int main(){
  7. TCompareNumSize oCompareSize;
  8. int iMaxNum = oCompareSize(1,2);
  9. std::cout<<" 最大数是:"<<iMaxNum<<endl;
  10. return 0;
  11. }


三 结论

binary_function与unary_function使用类似,只是参数不同,通过继承基类,重写operator即可实现我们
想要的效果,这两个api,其实我们自定义自己的数据结构基类,定义纯虚函数或虚函数,子类重写一样可以达到效
果,为了图方便。你也可以包含C++的头文件去使用。




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值