名稱空間
變體
操作

std::ranges::drop_view<V>::begin

來自 cppreference.com
< cpp‎ | ranges‎ | drop view
 
 
範圍庫 (Ranges library)
範圍介面卡 (Range adaptors)
 
 
constexpr auto begin()

    requires (!(/*simple-view*/<V> &&
                 ranges::random_access_range<const V> &&

                 ranges::sized_range<const V>));
(1) (C++20 起)
constexpr auto begin() const

    requires ranges::random_access_range<const V> &&

             ranges::sized_range<const V>;
(2) (C++20 起)

返回指向 drop_view 首元素的迭代器,即指向底層檢視的第 N 個元素的迭代器,如果底層檢視的元素少於 N 個,則返回指向底層檢視末尾的迭代器。

如果 V 不是 random_access_rangesized_range,為了提供 range 概念所要求的攤銷常數時間複雜度,過載 (1) 會將結果快取在底層 cache_ 物件中,以供後續呼叫使用。

目錄

[編輯] 返回值

ranges::next(ranges::begin(base_), count_, ranges::end(base_)).

[編輯] 示例

#include <array>
#include <concepts>
#include <iostream>
#include <iterator>
#include <ranges>
 
void println(std::ranges::range auto const& range)
{
    for (auto const& elem : range)
        std::cout << elem;
    std::cout << '\n';
}
 
int main()
{
    std::array hi{'H', 'e', 'l', 'l', 'o', ',', ' ', 'C', '+', '+', '2', '0', '!'};
    println(hi);
 
    const auto pos = std::distance(hi.begin(), std::ranges::find(hi, 'C'));
    auto cxx = std::ranges::drop_view{hi, pos};
    std::cout << "*drop_view::begin() == '" << *cxx.begin() << "'\n";
//  *cxx.begin() = 'c'; // undefined: 'views' are to be used as observers
    println(cxx);
}

輸出

Hello, C++20!
*drop_view::begin() == 'C'
C++20!

[編輯] 缺陷報告

下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。

缺陷報告 應用於 釋出時的行為 正確的行為
LWG 3482 C++20 const 過載可以與非大小範圍一起呼叫 const 過載需要 sized_range

[編輯] 另請參閱

返回一個迭代器或一個哨兵到末尾
(公共成員函式) [編輯]
返回指向範圍開頭的迭代器
(定製點物件)[編輯]
返回指示範圍末尾的哨兵
(定製點物件)[編輯]