std::ranges::in_found_result
来自cppreference.com
| 在标头 <algorithm> 定义
|
||
| template< class I > struct in_found_result; |
(C++20 起) | |
ranges::in_found_result 是类模板,提供存储一个迭代器和一个布尔标志为单个单元的方式。
除了下面显示的成员外,此类模板没有其他基类或数据成员,从而它适用于结构化绑定。
此类模板的所有特殊成员函数均为隐式声明,这使得所有特化都为聚合类,并传播数据成员上相应的操作的平凡性、潜在抛出性及 constexpr 性质。
目录 |
[编辑] 模板形参
| I | - | ranges::in_found_result 所存储的迭代器类型
|
[编辑] 数据成员
| 成员名字 | 定义 |
| in |
I 类型的值(假定为迭代器)。它被声明带有 [[no_unique_address]] 属性。 (公开成员对象) |
| found |
bool 类型的标志(可能显示是否能找到合适的范围)。 (公开成员对象) |
[编辑] 成员函数
std::ranges::in_found_result::operator in_found_result<I2>
| template<class I2> requires std::convertible_to<const I&, I2> |
(1) | |
| template<class I2> requires std::convertible_to<I, I2> |
(2) | |
通过从 *this 的每个数据成员构造结果的对应成员,将 *this 转换为结果。
1) 等价于 return {in, found};。
2) 等价于 return {std::move(in), found};。
[编辑] 标准库
下列标准库函数以 ranges::in_found_result 为返回类型:
算法函数 | |
| (C++20) |
生成元素范围的下一个字典序更大的排列 (算法函数对象) |
| (C++20) |
生成元素范围的下一个字典序更小的排列 (算法函数对象) |
[编辑] 概要
namespace std::ranges { template<class I> struct in_found_result { [[no_unique_address]] I in; bool found; template<class I2> requires std::convertible_to<const I&, I2> constexpr operator in_found_result<I2>() const & { return {in, found}; } template<class I2> requires std::convertible_to<I, I2> constexpr operator in_found_result<I2>() && { return {std::move(in), found}; } }; }
[编辑] 注解
每个使用这一族返回类型的标准库算法都声明了新的别名类型,例如 using merge_result = in_in_out_result<I1, I2, O>;。
这些别名的名称由算法名添加 “_result”组成。故 std::ranges::merge 的返回类型命名为 std::ranges::merge_result。
不同于 std::pair 和 std::tuple,此类模板的拥有名字有意义的数据成员。
[编辑] 示例
运行此代码
#include <algorithm> #include <iostream> #include <iterator> #include <ranges> int main() { int v[] {1, 2, 3}; const auto result = std::ranges::next_permutation(v); std::ranges::for_each(std::cbegin(v), result.in, [](int e) {std::cout << e << ' ';}); std::cout << std::boolalpha << "\n" "result.found: " << result.found << '\n'; }
输出:
1 3 2 result.found = true
[编辑] 参阅
| 实现二元组,即一对值 (类模板) | |
| (C++11) |
实现固定大小的容器,可保有类型相异的元素 (类模板) |