类模板
<functional>

std::less

template <class T> struct less;
函数对象类,用于小于比较
二元函数对象类,其调用返回其第一个参数是否小于第二个参数(由 operator < 返回)。

泛指,函数对象 是一个类的实例,该类定义了成员函数operator()。这个成员函数允许对象以与函数调用相同的语法使用。

它的定义与以下行为相同:

1
2
3
template <class T> struct less : binary_function <T,T,bool> {
  bool operator() (const T& x, const T& y) const {return x<y;}
};
1
2
3
4
5
6
template <class T> struct less {
  bool operator() (const T& x, const T& y) const {return x<y;}
  typedef T first_argument_type;
  typedef T second_argument_type;
  typedef bool result_type;
};

此类对象可用于标准算法,例如 sortmergelower_bound

模板参数

T
函数调用中用于比较的参数类型。
该类型应支持操作(operator<)。

成员类型

成员类型定义说明
first_argument_typeT成员 operator() 的第一个参数的类型
second_argument_typeT成员 operator() 的第二个参数的类型
result_typebool成员 operator() 返回的类型

成员函数

bool operator() (const T& x, const T& y)
成员函数,返回第一个参数是否小于第二个参数(x<y)。

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
// less example
#include <iostream>     // std::cout
#include <functional>   // std::less
#include <algorithm>    // std::sort, std::includes

int main () {
  int foo[]={10,20,5,15,25};
  int bar[]={15,10,20};
  std::sort (foo, foo+5, std::less<int>());  // 5 10 15 20 25
  std::sort (bar, bar+3, std::less<int>());  //   10 15 20
  if (std::includes (foo, foo+5, bar, bar+3, std::less<int>()))
    std::cout << "foo includes bar.\n";
  return 0;
}

输出

foo includes bar.


另见