std::optional<T>::begin
来自cppreference.com
<tbody>
</tbody>
constexpr iterator begin() noexcept; |
(C++26 起) | |
constexpr const_iterator begin() const noexcept; |
(C++26 起) | |
若 *this 含值,则返回指向所含值的迭代器。否则返回尾后迭代器值。
返回值
若 has_value() 为 true 则返回指向所含值的迭代器。否则返回尾后迭代器。
复杂度
常数。
注解
| 功能特性测试宏 | 值 | 标准 | 功能特性 |
|---|---|---|---|
__cpp_lib_optional_range_support |
202406L |
(C++26) | std::optional 的范围支持
|
示例
运行此代码
#include <optional>
#include <print>
#include <vector>
int main()
{
constexpr std::optional<int> none{std::nullopt};
constexpr std::optional<int> some{42};
static_assert(none.begin() == none.end());
static_assert(some.begin() != some.end());
// 支持范围 for 循环
for (int i : none)
std::println("'none' 的值为 {}", i);
for (int i : some)
std::println("'some' 的值为 {}", i);
std::optional<std::vector<int>> many({0, 1, 2});
for (const auto& v : many)
std::println("'many' 的值为 {}", v);
}
输出:
'some' 的值为 42
'many' 的值为 [0, 1, 2]
参阅
(C++26) |
返回指向末尾的迭代器 (公开成员函数) |