std::ranges::split_view<V,Pattern>::begin
出自cppreference.com
< cpp | ranges | split view
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) |
返回指向範圍起始的迭代器 (定製點對象) |