std::ranges:: views:: values, std::ranges:: values_view
|
||||||||||||||||||||||
| Range primitives | |||||||
|
|||||||
| Range concepts | |||||||||||||||||||
|
|||||||||||||||||||
| Range factories | |||||||||
|
|||||||||
| Range adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||
| Helper items | |||||||||||||||||
|
|
||||||||||||||||
|
定义于头文件
<ranges>
|
||
|
template
<
class
R
>
using values_view = ranges:: elements_view < R, 1 > ; |
(1) | (C++20 起) |
|
namespace
views
{
inline
constexpr
auto
values
=
ranges
::
elements
<
1
>
;
|
(2) | (C++20 起) |
接受一个由
类元组
值(例如
std::tuple
或
std::pair
)构成的
view
,并生成一个其值类型为被适配视图值类型中
第二个
元素的视图。
目录 |
注释
values_view 可用于从关联容器中提取 值 ,例如
std::map<int, std::string> map{{1, "alpha"}, {2, "beta"}}; for (auto const& value : std::views::values(map)) std::cout << value << ' '; // 输出:alpha beta
示例
#include <iostream> #include <map> #include <ranges> int main() { const auto list = {std::pair{1, 11.1}, {2, 22.2}, {3, 33.3}}; std::cout << "列表中pair::second的值: "; for (double value : list | std::views::values) std::cout << value << ' '; std::map<char, int> map{{'A', 1}, {'B', 2}, {'C', 3}, {'D', 4}, {'E', 5}}; auto odd = [](int x) { return 0 != (x & 1); }; std::cout << "\n映射中的奇数值: "; for (int value : map | std::views::values | std::views::filter(odd)) std::cout << value << ' '; std::cout << '\n'; }
输出:
列表中pair::second的值: 11.1 22.2 33.3 映射中的奇数值: 1 3 5
缺陷报告
以下行为变更缺陷报告被追溯应用于先前发布的C++标准。
| 缺陷报告 | 应用于 | 发布时的行为 | 正确行为 |
|---|---|---|---|
| LWG 3563 | C++20 |
keys_view
因使用
views::all_t
而无法参与 CTAD
|
移除 views::all_t |
参见
|
(C++20)
|
获取由键值对组成的
view
,生成每个键值对中首元素的
view
(类模板) (范围适配器对象) |
获取由
tuple-like
值组成的
view
及数字N,生成每个元组第N个元素的
view
(类模板) (范围适配器对象) |
|
|
类BLAS的valarray切片:起始索引、长度、步长
(类) |