命名空间
变体
操作

std::ranges::views::keys, std::ranges::keys_view

来自 cppreference.com
< cpp‎ | ranges
 
 
范围库
范围适配器
 
在头文件中定义 <ranges>
template< class R >
using keys_view = ranges::elements_view<R, 0>;
(1) (自 C++20 起)
namespace views {

    inline constexpr auto keys = ranges::elements<0>;

}
(2) (自 C++20 起)

接受一个类似元组值的view(例如 std::tuplestd::pair),并生成一个值类型为适配视图的值类型的第一个元素的视图。

1) ranges::elements_view<R, 0> 的别名。
2) RangeAdaptorObject(以及 RangeAdaptorClosureObject)。表达式 views::keys(e)keys_view<views::all_t<decltype((e))>>{e} 相当于任何合适的子表达式 e

内容

[编辑] 注释

keys_view 可用于从关联容器中提取,例如

std::map<std::string, int> map{{"one", 1}, {"two", 2}};
 
for (auto const& key : std::views::keys(map))
    std::cout << key << ' ';
// prints: one two

[编辑] 示例

显示粒子物理学中每种夸克类型的数值。

#include <iomanip>
#include <iostream>
#include <locale>
#include <ranges>
#include <string>
#include <tuple>
#include <vector>
 
int main()
{
    const std::vector<std::tuple<std::string, double, bool>> quark_mass_charge
    {
        // name, MeV/c², has positive electric-charge:
        {"up", 2.3, true}, {"down", 4.8, false},
        {"charm", 1275, true}, {"strange", 95, false},
        {"top", 173'210, true}, {"bottom", 4'180, false},
    };
 
    std::cout.imbue(std::locale("en_US.utf8"));
    std::cout << "Quark name:  │ ";
    for (std::string const& name : std::views::keys(quark_mass_charge))
        std::cout << std::setw(9) << name << " │ ";
 
    std::cout << "\n" "Mass MeV/c²: │ ";
    for (const double mass : std::views::values(quark_mass_charge))
        std::cout << std::setw(9) << mass << " │ ";
 
    std::cout << "\n" "E-charge:    │ ";
    for (const bool pos : std::views::elements<2>(quark_mass_charge))
        std::cout << std::setw(9) << (pos ? "+2/3" : "-1/3") << " │ ";
    std::cout << '\n';
}

输出

Quark name:  │        up │      down │     charm │   strange │       top │    bottom │
Mass MeV/c²: │       2.3 │       4.8 │     1,275 │        95 │   173,210 │     4,180 │
E-charge:    │      +2/3 │      -1/3 │      +2/3 │      -1/3 │      +2/3 │      -1/3 │

[编辑] 缺陷报告

以下行为更改缺陷报告已追溯应用于之前发布的 C++ 标准。

DR 应用于 已发布的行为 正确行为
LWG 3563 C++20 keys_view 由于使用 views::all_t 无法参与 CTAD views::all_t 已移除

[编辑] 另请参阅

接受由类似对的view 组成,并生成每个对的第二个元素的view
(类模板) (范围适配器对象)[编辑]
接受由类似元组值组成的view 以及数字 N,并生成每个元组的第 N 个元素的view
(类模板) (范围适配器对象)[编辑]
valarray 的类似 BLAS 切片:起始索引、长度、步长
(类) [编辑]