std::ranges::split_view<V,Pattern>::begin
来自cppreference.com
<tbody>
</tbody>
constexpr /*iterator*/ begin(); |
(C++20 起) | |
返回指向找到的第一个子范围的迭代器。
为提供 range 概念要求的均摊常数复杂度,此函数在 split_view 中缓存了结果(通过 cached_begin_ 成员)以供后续调用所用。
让 base_ 作为底层数据成员。等价于:
constexpr /*iterator*/ begin()
{
if (!cached_begin_.has_value())
cached_begin_ = this->find_next(ranges::begin(base_));
return {*this, ranges::begin(base_), cached_begin_.value()};
}
返回值
迭代器。
复杂度
均摊的 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()})
<< "\n子字符串: ";
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()})
<< "\n字母: ";
for (auto letter : letters)
std::cout << std::string_view(letter) << ' ';
std::cout << '\n';
}
输出:
begin(): "Keep"
子字符串: "Keep" "moving" "forward" ""
begin(): "K"
字母: 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) |
返回指向范围起始的迭代器 (定制点对象) |