Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 138995
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T07:21:21+00:00 2026-05-11T07:21:21+00:00

What is the benefit of inheriting from std::binary_function (or std::unary_function)? For example I have

  • 0

What is the benefit of inheriting from std::binary_function (or std::unary_function)?

For example I have such code:

class Person {  public:     Person();     Person(int a, std::string n);     Person(const Person& src);      int age;     std::string name;  };   Person::Person()            : age(0)              , name('')                {};   Person::Person(int a, std::string n)  : age(a)  , name(n)  {};   Person::Person(const Person& src)  {    age = src.age;    name = src.name;  };   struct PersonPrint : public std::unary_function<Person, void>{    void operator() (Person p){      std::cout << ' Person age: ' << p.age                 << ' name: ' << p.name << std::endl;    }  };   struct PersonGreater : public std::binary_function<Person, Person, bool>{    bool operator()(const Person& p1, const Person p2){      if (p1.age > p2.age) return true;      if (p1.name.compare(p2.name) > 0) return true;      return false;    }  };   int main(int count, char** args)  {    std::vector<Person> personVec;    Person p1(10, 'Person1');    Person p2(12, 'Person2');    Person p3(12, 'Person3');     personVec.push_back(p1);    personVec.push_back(p2);    personVec.push_back(p3);     std::cout << 'before sort: ' << std::endl;    std::for_each(personVec.begin(), personVec.end(), PersonPrint());    std::sort(personVec.begin(), personVec.end(), PersonGreater());    std::cout << 'after: ' << std::endl;    std::for_each(personVec.begin(), personVec.end(), PersonPrint());  } 

But I also could write this code without inheritance form std::unary_function/std::binary_function?

 struct PersonPrint {      void operator() (Person p) {          std::cout << ' Person age: ' << p.age << ' name: ' << p.name << std::endl;       }   };    struct PersonGreater {      bool operator()(const Person& p1, const Person p2) {          if (p1.age > p2.age) return true;           if (p1.name.compare(p2.name) > 0) return true;           return false;       }   }; 

UPDATED

std::binary_function and std::unary_function are deprecated as of C++11 see comment by @AlexandreC.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-11T07:21:22+00:00Added an answer on May 11, 2026 at 7:21 am

    Inheritance from [unary|binary]_function just gives you an additional typedefs in your class:

    For unary_function

    argument_type result_type 

    For binary_function

    first_argument_type second_argument_type result_type  

    Which are those types you pass to [unary|binary]_function. In your case there is no benefits.

    If you ever going to use your Functors with other std Functors modificators like not1, bind1st you have to inherit from [unart|binart]_function.

    And if you are going to store this template information for your purpose it is better to use ready solution.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

What benefit or implications could we get with Python code like this: class some_class(parent_class):
Inheriting code from other developers has made me a firm believer in keeping as
I'm writing a tool which would benefit from knowing which of a class' instance
If I have a class like this: public class Foo { public IEnumerable<Bar> Bars
I don't necessarily see a grandiose benefit of interfaces inheriting interfaces. Consider the following
What benefit do I derive from installing Sql Express with Visual Studio (2010) when
Is there any benefit to include the length specifier in a format string for
Is there a benefit to passing a string in your url patters vs a
The benefit of defining common virtual functions in the base class is that we
What is the benefit of having generic constructor for a non-generic class? Java spec

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.