- ranges[meta header]
- std::ranges[meta namespace]
- class template[meta id-type]
- cpp23[meta cpp]
namespace std::ranges {
template<input_range... Views>
requires (view<Views> && ...) && (sizeof...(Views) > 0)
class zip_view : public view_interface<zip_view<Views...>> {…… }; // (1)
namespace views {
inline constexpr /*unspecified*/ zip = /*unspecified*/; // (2)
}
}
zip_view
は複数のRangeから要素を1つずつ取得したtuple
を要素とするview
。
zip_view
の要素を1つ取得するごとに、各Rangeの要素を1つずつ取得する。
zipするRangeのサイズが異なっている場合、zip_view
のサイズはそれらの中で最小のサイズとなる。
- (1):
zip_view
のクラス定義 - (2):
zip_view
を生成するカスタマイゼーションポイントオブジェクト(Rangeアダプタオブジェクトではない)
borrowed | sized | output | input | forward | bidirectional | random_access | contiguous | common | viewable | view |
---|---|---|---|---|---|---|---|---|---|---|
(1) | 〇 | 〇 | (2) | (3) | (4) | (5) | ○ | ○ |
- (1): zipするすべてのRangeが
sized_range
のとき - (2): zipするすべてのRangeが
forward_range
のとき - (3): zipするすべてのRangeが
bidirectional_range
のとき - (4): zipするすべてのRangeが
random_access_range
のとき - (5): zip-is-commonのとき
- (2): 式
views::zip(Es...)
の効果は次の通りEs
が空でないとき、zip_view<
views::all_t
<decltype((Es))>...>(Es...)
と等しいEs
が空のとき、auto(
views::empty
<
tuple
<>>)
と等しい
本説明に用いる説明専用要素を以下のように定義する。
namespace std::ranges {
// 説明専用
template<class... Rs>
concept zip-is-common =
(sizeof...(Rs) == 1 && (common_range<Rs> && ...)) ||
(!(bidirectional_range<Rs> && ...) && (common_range<Rs> && ...)) ||
((random_access_range<Rs> && ...) && (sized_range<Rs> && ...));
}
名前 | 説明 | 対応バージョン |
---|---|---|
(constructor) |
コンストラクタ | C++23 |
begin |
先頭を指すイテレータを取得する | C++23 |
end |
番兵を取得する | C++23 |
size |
要素数を取得する | C++23 |
名前 | 説明 | 対応バージョン |
---|---|---|
empty |
Rangeが空かどうかを判定する | C++20 |
operator bool |
Rangeが空でないかどうかを判定する | C++20 |
front |
先頭要素への参照を取得する | C++20 |
back |
末尾要素への参照を取得する | C++20 |
cbegin |
定数イテレータを取得する | C++23 |
cend |
定数イテレータ(番兵)を取得する | C++23 |
operator[] |
要素へアクセスする | C++20 |
名前 | 説明 | 対応バージョン |
---|---|---|
(deduction_guide) |
クラステンプレートの推論補助 | C++23 |
#include <ranges>
#include <vector>
#include <list>
#include <unordered_map>
#include <print>
int main() {
std::vector v = {1, 2};
const std::list l = {'a', 'b', 'c'};
std::println("{}", std::views::zip(v, l));
for (auto&& [i, c] : std::views::zip(v, l)) {
i *= 10; // 要素を書き換えても良い
}
std::println("{}", std::views::zip(v, l));
// zipした結果を連想コンテナに変換する
const auto m = std::views::zip(v, l) | std::ranges::to<std::unordered_map<int, char>>();
std::println("{}", m);
// 何もzipしていないときは空になる
std::println("{}", std::views::zip());
}
- std::views::zip[color ff0000]
- std::ranges::to[link to.md]
[(1, 'a'), (2, 'b')]
[(10, 'a'), (20, 'b')]
{20: 'b', 10: 'a'}
[]
- C++23
- Clang: 16.0 [mark verified]
- GCC: 13.2 [mark verified]
- ICC: ??
- Visual C++: ??
elements_view
zipの逆(タプルから要素を取り出す)zip_transform_view
zipして関数を適用する