跳到主要内容

std::multimap key_comp() 方法

// Const version only
key_compare key_comp() const;

返回比较键的函数对象,它是此容器的 构造函数 参数 comp 的一个副本。

参数

(无)

返回值

键比较函数对象。

复杂度

常数 - O(1)

异常

(无)

示例

Main.cpp
#include <cassert>
#include <iostream>
#include <map>

// Example module 97 key compare function
struct ModCmp {
bool operator()(const int lhs, const int rhs) const
{
return (lhs % 97) < (rhs % 97);
}
};

int main()
{
std::multimap<int, char, ModCmp> cont;
cont = { { 1, 'a' }, { 2, 'b' }, { 3, 'c' }, { 4, 'd' }, { 5, 'e' } };

auto comp_func = cont.key_comp();

for (auto it : cont) {
bool before = comp_func(it.first, 100);
bool after = comp_func(100, it.first);

std::cout << '(' << it.first << ',' << it.second;
if (!before && !after)
std::cout << ") equivalent to key 100\n";
else if (before)
std::cout << ") goes before key 100\n";
else if (after)
std::cout << ") goes after key 100\n";
else
assert(0); // Cannot happen
}
}
输出
(1,a) goes before key 100
(2,b) goes before key 100
(3,c) equivalent to key 100
(4,d) goes after key 100
(5,e) goes after key 100
本文来源于 此 CppReference 页面。它可能为了改进或编辑者的偏好而进行了修改。点击“编辑此页面”查看本文档的所有更改。
悬停查看原始许可证。

std::multimap key_comp() 方法

// Const version only
key_compare key_comp() const;

返回比较键的函数对象,它是此容器的 构造函数 参数 comp 的一个副本。

参数

(无)

返回值

键比较函数对象。

复杂度

常数 - O(1)

异常

(无)

示例

Main.cpp
#include <cassert>
#include <iostream>
#include <map>

// Example module 97 key compare function
struct ModCmp {
bool operator()(const int lhs, const int rhs) const
{
return (lhs % 97) < (rhs % 97);
}
};

int main()
{
std::multimap<int, char, ModCmp> cont;
cont = { { 1, 'a' }, { 2, 'b' }, { 3, 'c' }, { 4, 'd' }, { 5, 'e' } };

auto comp_func = cont.key_comp();

for (auto it : cont) {
bool before = comp_func(it.first, 100);
bool after = comp_func(100, it.first);

std::cout << '(' << it.first << ',' << it.second;
if (!before && !after)
std::cout << ") equivalent to key 100\n";
else if (before)
std::cout << ") goes before key 100\n";
else if (after)
std::cout << ") goes after key 100\n";
else
assert(0); // Cannot happen
}
}
输出
(1,a) goes before key 100
(2,b) goes before key 100
(3,c) equivalent to key 100
(4,d) goes after key 100
(5,e) goes after key 100
本文来源于 此 CppReference 页面。它可能为了改进或编辑者的偏好而进行了修改。点击“编辑此页面”查看本文档的所有更改。
悬停查看原始许可证。