- ranges[meta header]
- std::ranges[meta namespace]
- class template[meta id-type]
- cpp20[meta cpp]
namespace std::ranges {
template<input_range V, indirect_unary_predicate<iterator_t<V>> Pred>
requires view<V> && is_object_v<Pred>
class filter_view : public view_interface<filter_view<V, Pred>> { …… }; // (1)
namespace views {
inline constexpr /*unspecified*/ filter = /*unspecified*/; // (2)
}
}
- input_range[link input_range.md]
- indirect_unary_predicate[link /reference/iterator/indirect_unary_predicate.md]
- iterator_t[link iterator_t.md]
- view[link view.md]
- is_object_v[link /reference/type_traits/is_object.md]
- view_interface[link view_interface.md]
- (1): 指定された条件
Predを満たす要素だけが要素となるview
- (2):
filter_viewを生成するRangeアダプタオブジェクト
元のRangeから条件を満たす要素を探す処理は遅延評価される。
- 初めてメンバ関数
beginが呼び出されたときに先頭の要素を決定し、残りはイテレータが進むときに求める。
beginは償却定数時間で実行できなければならないため、beginの値はキャッシュされる。
filter_viewの要素を書き換えてもよいが、書き換えた後の要素がPredを満たさない場合は未定義動作となる。
| borrowed |
sized |
output |
input |
forward |
bidirectional |
random_access |
contiguous |
common |
viewable |
view |
|
|
※ |
○ |
※ |
※ |
|
|
※ |
○ |
○ |
※ Vに従う
- (2): 式
views::filter(E, P)の効果はfilter_view(E, P)と等しい
#include <ranges>
#include <iostream>
int main() {
using namespace std;
int a[] = {1, 2, 3, 4, 5};
for (int& i : a | views::filter([](int x){ return x % 2 == 0; })) {
cout << i;
i *= 2; // filterした要素を2倍にする (2倍しても条件を満たすことに注意)
}
cout << '\n';
for (int i : a) {
cout << i;
}
}
- views::filter[color ff0000]