std::optional<T>::begin
来自cppreference.com
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) |
返回指向末尾的迭代器 (公开成员函数) |