std::ranges::split_view<V,Pattern>::begin
来自 cppreference.com
< cpp | ranges | split view
constexpr /*iterator*/ begin(); |
(自 C++20 起) | |
返回指向第一个找到的子范围的迭代器。
为了提供range
概念所需的均摊常数时间复杂度,此函数在split_view
中缓存结果以供后续调用使用。等效于
constexpr /*iterator*/ begin() { if (!cached_begin_.has_value()) cached_begin_ = this->find_next(ranges::begin(base_)); return {*this, ranges::begin(base_), cached_begin_.value()}; }
仅供说明的数据成员base_
和 cached_begin_
在此处描述。
内容 |
[编辑] 参数
(无)
[编辑] 返回值
一个迭代器。
[编辑] 复杂度
均摊O(1)。
[编辑] 示例
运行此代码
#include <iomanip> #include <iostream> #include <ranges> #include <string_view> int main() { constexpr std::string_view sentence{"Keep..moving..forward.."}; constexpr std::string_view delim{".."}; std::ranges::split_view words{sentence, delim}; std::cout << "begin(): " << std::quoted(std::string_view{*words.begin()}) << "\nSubstrings: "; for (auto word : words) std::cout << std::quoted(std::string_view(word)) << ' '; std::ranges::split_view letters{sentence, std::string_view{""}}; std::cout << "\nbegin(): " << std::quoted(std::string_view{*letters.begin()}) << "\nLetters: "; for (auto letter : letters) std::cout << std::string_view(letter) << ' '; std::cout << '\n'; }
输出
begin(): "Keep" Substrings: "Keep" "moving" "forward" "" begin(): "K" Letters: K e e p . . m o v i n g . . f o r w a r d . .
[编辑] 另请参阅
返回指向结尾的迭代器或哨兵 (公有成员函数) | |
返回指向开头的迭代器 ( std::ranges::lazy_split_view<V,Pattern> 的公有成员函数) | |
(C++20) |
返回指向范围开头的迭代器 (定制点对象) |