std::ranges::zip_view<Views...>::size
From cppreference.com
| constexpr auto size() requires (ranges::sized_range<Views> && ...); |
(1) | (C++23から) |
| constexpr auto size() const requires (ranges::sized_range<const Views> && ...); |
(2) | (C++23から) |
zip_view の要素数を返します。これは、各基となる(アダプタされた)範囲が sized_range を満たす場合にのみ提供されます。
以下と等価です。
return std::apply ( [](auto... sizes) { using CT = /*make-unsigned-like-t*/<std::common_type_t<decltype(sizes)...>>; return ranges::min({CT(sizes)...}); }, /*tuple-transform*/(ranges::size, views_) );
目次 |
[編集] パラメータ
(なし)
[編集] 戻り値
要素数。これは、アダプタされたすべての view のサイズのうち最小値です。
[編集] 例
このコードを実行
#include <algorithm> #include <cassert> #include <deque> #include <forward_list> #include <ranges> #include <vector> int main() { auto x = std::vector{1, 2, 3, 4, 5}; auto y = std::deque{'a', 'b', 'c'}; auto z = std::forward_list{1., 2.}; auto v1 = std::views::zip(x, y); assert(v1.size() == std::min(x.size(), y.size())); assert(v1.size() == 3); [[maybe_unused]] auto v2 = std::views::zip(x, z); // auto sz = v2.size(); // Error, v2 does not have size(): static_assert(not std::ranges::sized_range<decltype(z)>); }
[編集] 関連項目
| (C++20) |
rangeのサイズと等しい整数を返す (カスタマイゼーションポイントオブジェクト) |
| (C++20) |
rangeのサイズと等しい符号付き整数を返す (カスタマイゼーションポイントオブジェクト) |