std::less
std::less
定义于头文件
<functional> |
||
template< class T > struct less; |
(C++14 前) | |
template< class T = void > struct less; |
(C++14 起) | |
进行比较的函数对象。调用类型 T
上的 operator< ,除非特化。
特化
std::less
的特化为任何指针类型产生严格全序,即使内建的 operator< 不如此。严格全序在 std::less 、 std::greater 、 std::less_equal 和 std::greater_equal 对该指针类型的特化间一致,且亦与对应的内建运算符( <
、 >
、 <=
及 >=
)所强加的部分顺序一致。
若特化 |
(C++14 起) |
标准库提供
|
(C++14 起) |
成员类型
类型 | 定义 |
result_type (C++17 中弃用) |
bool |
first_argument_type (C++17 中弃用) |
T |
second_argument_type (C++17 中弃用) |
T |
成员函数
operator()
|
检查第一参数是否小于第二个 (公开成员函数) |
std::less::operator()
bool operator()( const T& lhs, const T& rhs ) const;
|
(C++14 前) | |
constexpr bool operator()( const T& lhs, const T& rhs ) const;
|
(C++14 起) | |
检查 lhs
是否小于 rhs
。
参数
lhs, rhs | - | 要比较的值 |
返回值
若 lhs < rhs 则为 true ,否则为 false 。
异常
(无)
可能的实现
constexpr bool operator()(const T &lhs, const T &rhs) const |
示例
#include <functional>
#include <iostream> template <typename A, typename B, typename U = std::less<int>>
bool f(A a, B b, U u = U())
{
return u(a, b);
} int main()
{
std::cout << std::boolalpha;
std::cout << f(, ) << '\n';
std::cout << f(, ) << '\n';
}
输出:
true
false
以上是在网上查的std::less用法。实际使用时,比如
std::map<uint64_t,Eigen::Vector2i, std::less<uint64_t>
这里第三个参数的作用为,定义map中key值的排序规则,这里即为按<排序。
std::less的更多相关文章
- 【NX二次开发】NX内部函数,libuifw.dll文件中的内部函数
本文分为两部分:"带参数的函数"和 "带修饰的函数". 浏览这篇博客前请先阅读: [NX二次开发]NX内部函数,查找内部函数的方法 带参数的函数: void U ...
- C++ std::set
std::set template < class T, // set::key_type/value_type class Compare = less<T>, // set::k ...
- C++ std::priority_queue
std::priority_queue template <class T, class Container = vector<T>, class Compare = less< ...
- C++ std::queue
std::queue template <class T, class Container = deque<T> > class queue; FIFO queue queue ...
- C++ std::multimap
std::multimap template < class Key, // multimap::key_type class T, // multimap::mapped_type class ...
- C++ std::map
std::map template < class Key, // map::key_type class T, // map::mapped_type class Compare = less ...
- C++ std::list
std::list template < class T, class Alloc = allocator > class list; List Lists are sequence co ...
- C++ std::forward_list
std::forward_list template < class T, class Alloc = allocator > class forward_list; Forward li ...
- C++ std::deque
std::deque template < class T, class Alloc = allocator > class deque; Double ended queue deque ...
- C++ std::array
std::array template < class T, size_t N > class array; Code Example #include <iostream> ...
随机推荐
- HDU2296 Ring —— AC自动机 + DP
题目链接:https://vjudge.net/problem/HDU-2296 Ring Time Limit: 2000/1000 MS (Java/Others) Memory Limit ...
- TCP/IP协议数据包文件PCAP分析器
一.设计原理 1.PCAP文件构成 参考http://blog.csdn.net/gulu_gulu_jp/article/details/50494909 PCAP文件由一个PCAP文件头和多个PC ...
- hdmap相关单词
交叉口(junction) 交叉口组(junctiongroup)
- 设置document.domain实现js跨域注意点
转自:http://www.cnblogs.com/fsjohnhuang/archive/2011/12/07/2279554.html document.domain 用来得到当前网页的域名.比如 ...
- 分享知识-快乐自己:论 Mybatis中的关联关系(一对多,多对一,多对多)
论:一对多:(举例一个省有多个市)就是实体类中有(市)类型集合属性:多对一:(多个市有一个共同的省)就是类中有(省)类型的属性.下面来介绍:一对一.多对一的使用方式. 一对多方: package ml ...
- Android sdk 搭建
下载安装 http://pan.baidu.com/wap/share/home?uk=67915989&third=0 搭建Android环境时,无论使用的Eclipse还是Android ...
- C#多线程学习 之 线程池[ThreadPool]
在多线程的程序中,经常会出现两种情况: 一种情况: 应用程序中,线程把大部分的时间花费在等待状态,等待某个事件发生,然后才能给予响应 这一般使用ThreadPo ...
- ICE 迁移64位安装问题
昨天手贱,在apt-get install 后有一大堆,上百个安装包not upgrade, 发现有提示apt-get autoremove,犹豫了很久后还是忍不住执行了autoremove:这个命令 ...
- HihoCoder1643 : 最少换乘([Offer收割]编程练习赛37)(bfs)
描述 小Ho居住的城市有N条公交车线路,其中第i条线路上有Ki个车站. 某些线路之间会有公共的车站,小Ho可以在这些车站从一条线路换乘到另一条线路. 现在给定N条公交车线路以及两个车站S和E,你能帮助 ...
- bzoj 4319 Suffix reconstruction —— 贪心构造
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4319 思维还是不行...这样的构造都没思路... 首先,我们可以按 rank 的顺序从小到大 ...