名前空間
変種
操作

std::ranges::filter_view<V,Pred>::iterator

From cppreference.com
< cpp‎ | ranges‎ | filter view
 
 
Rangesライブラリ
Rangeアダプタ
 
 
class /*iterator*/;
(C++20以降)
(説明用*)

filter_view::begin の戻り値の型です。

Vbidirectional_range をモデルとする場合は bidirectional_iteratorVforward_range をモデルとする場合は forward_iterator、それ以外の場合は input_iterator です。

このイテレータが指す要素の変更は許可されますが、結果の値がフィルターの述語を満たさない場合は未定義の動作となります。

目次

[編集] メンバ型

定義
iterator_concept
iterator_category
V
forward_range)

Cstd::iterator_traits<ranges::iterator_t<V>>::iterator_category とします。

value_type ranges::range_value_t<V>
difference_type ranges::range_difference_t<V>

[編集] データメンバ

メンバ 説明
ranges::iterator_t<V> current_ (private) 基底の view へのイテレータ
(説明用のメンバオブジェクト*)
ranges::filter_view<V, Pred>* parent_ (private) 親となる filter_view オブジェクトへのポインタ
(説明用のメンバオブジェクト*)

[編集] メンバ関数

イテレータを構築する
(public member function)
基盤となるイテレータを返します。
(public member function)
基底のイテレータにフォワードします。
(public member function)
イテレータを進める
(public member function)
イテレータをデクリメントします。
(public member function)

std::ranges::filter_view::iterator::iterator

/*iterator*/()
    std::default_initializable<ranges::iterator_t<V>> が必要です = default;
(1) (C++20以降)
constexpr /*iterator*/( filter_view& parent,
                        ranges::iterator_t<V> current );
(2) (C++20以降)
1) current_parent_ を、それぞれ = ranges::iterator_t<V>() および = nullptr のデフォルトメンバ初期化子で初期化します。
2) current_std::move(current) で、parent_std::addressof(parent) で初期化します。

std::ranges::filter_view::iterator::base

constexpr const ranges::iterator_t<V>& base() const & noexcept;
(1) (C++20以降)
constexpr ranges::iterator_t<V> base() &&;
(2) (C++20以降)
1) return current_; と同等です。
2) return std::move(current_); と同等です。

std::ranges::filter_view::iterator::operator*,->

constexpr ranges::range_reference_t<V> operator*() const;
(1) (C++20以降)
constexpr ranges::iterator_t<V> operator->() const

    requires /*has-arrow*/<ranges::iterator_t<V>> &&

             std::copyable<ranges::iterator_t<V>>;
(2) (C++20以降)
1) return *current_; と同等です。
2) return current_; と同等です。

I において、/*has-arrow*/<I> は、I がそれぞれ input_iterator をモデルとするかまたは満たす場合、かつ I がポインタ型であるか、または requires(I i){ i.operator->();} が true である場合にモデル化されるか満たされます。

std::ranges::filter_view::iterator::operator++

constexpr /*iterator*/& operator++();
(1) (C++20以降)
constexpr void operator++( int );
(2) (C++20以降)
constexpr /*iterator*/ operator++( int )
    requires ranges::forward_range<V>;
(3) (C++20以降)
1) 同値:
current_ = ranges::find_if(std::move(++current_), ranges::end(parent_->base_),
                           std::ref(*parent_->pred_));
return *this;
.
2) ++*this;と同等です。
3) auto tmp = *this; ++*this; return tmp; と同等です。

std::ranges::filter_view::iterator::operator--

constexpr /*iterator*/& operator--()
    requires ranges::bidirectional_range<V>;
(1) (C++20以降)
constexpr /*iterator*/ operator--( int )
    requires ranges::bidirectional_range<V>;
(2) (C++20以降)
1) 同値:
do
    --current_;
while (!std::invoke(*parent_->pred_, *current_));
return *this;
.
2) auto tmp = *this; --*this; return tmp; と同等です。

[編集] 非メンバ関数

基底イテレータを比較する
(関数)
(C++20)
基底イテレータの間接参照の結果を関連する右辺値参照型にキャストする
(関数)
(C++20)
2つの基底イテレータが指すオブジェクトをスワップする
(関数)

operator==(std::ranges::filter_view::iterator)

friend constexpr bool operator==( const /*iterator*/& x, const /*iterator*/& y )
    requires std::equality_comparable<ranges::iterator_t<V>>;
(C++20以降)

return x.current_ == y.current_; と同等です。

!= 演算子は operator== から合成される。

この関数は、通常の 非修飾または修飾 lookup では可視でなく、std::ranges::filter_view::iterator が引数に関連付けられたクラスである場合にのみ、引数依存lookup によって見つけることができます。

iter_move(std::ranges::filter_view::iterator)

friend constexpr ranges::range_rvalue_reference_t<V>

iter_move( const /*iterator*/& i )

    noexcept(noexcept(ranges::iter_move(i.current_)));
(C++20以降)

return ranges::iter_move(i.current_); と同等です。

この関数は、通常の 非修飾または修飾 lookup では可視でなく、std::ranges::filter_view::iterator が引数に関連付けられたクラスである場合にのみ、引数依存lookup によって見つけることができます。

iter_swap(std::ranges::filter_view::iterator)

friend constexpr void iter_swap( const /*iterator*/& x, const /*iterator*/& y )

    noexcept(noexcept(ranges::iter_swap(x.current_, y.current_)))

        requires std::indirectly_swappable<ranges::iterator_t<V>>;
(C++20以降)

ranges::iter_swap(x.current_, y.current_) と同等です。

この関数は、通常の 非修飾または修飾 lookup では可視でなく、std::ranges::filter_view::iterator が引数に関連付けられたクラスである場合にのみ、引数依存lookup によって見つけることができます。

[編集] 不具合報告

以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。

DR 適用対象 公開された動作 正しい動作
P2259R1 C++20 メンバ型 iterator_category は常に定義されていました。 Vforward_range の場合にのみ定義されます。
LWG 3533 C++20 baseconst& オーバーロードは基底のイテレータをコピーしていました。 それへの参照を返していました。
LWG 3593 C++20 baseconst& オーバーロードは `noexcept` でない可能性がありました。 noexcept に変更されました
English 日本語 中文(简体) 中文(繁體)