std::ranges::cartesian_product_view<First, Vs...>::end
來自 cppreference.com
< cpp | ranges | cartesian product view
constexpr iterator<false> end() requires ((!/*simple-view*/<First> || ... || !/*simple-view*/<Vs>) && |
(1) | (C++23 起) |
constexpr iterator<true> end() const requires /*cartesian-product-is-common*/<const First, const Vs...>; |
(2) | (C++23 起) |
constexpr std::default_sentinel_t end() const noexcept; |
(3) | (C++23 起) |
返回代表 cartesian_product_view
結尾的迭代器或哨位。
令 bases_
為底層檢視的元組。
1,2) 等價於
auto check = [](auto& rng) { return __begin_or_first_end(rng); };
return iterator<__is_const>(/*tuple-transform*/(check, bases_));,
return iterator<__is_const>(/*tuple-transform*/(check, bases_));,
其中
- __is_const 對於 const-限定過載為 true,否則為 false。
- __is_empty 如果表示式 ranges::empty(rng) 對於除第一個之外的任何底層範圍中的 rng 為 true,則為 true,否則為 false。
- __begin_or_first_end(rng) 表示式等價於 __is_empty ? ranges::begin(rng) : /*cartesian-common-arg-end*/(rng),如果 rng 是第一個底層範圍,否則為 ranges::begin(rng)。
3) 等價於:return std::default_sentinel;。
目錄 |
[編輯] 引數
(無)
[編輯] 返回值
一個指向最後元素之後元素的迭代器,或一個與末尾迭代器比較相等的哨位。
[編輯] 示例
執行此程式碼
#include <array> #include <format> #include <iostream> #include <ranges> #include <string_view> #include <tuple> using namespace std::literals; int main() { constexpr auto a = std::array{ "bool"sv, "goto"sv, "extern"sv, "long"sv }; /* ^ ^ ^ ^ */ constexpr auto v = std::ranges::cartesian_product_view(a[0], a[1], a[2], a[3]); constexpr std::tuple<char const&, char const&, char const&, char const&> last{*(v.end() - 1)}; std::cout << std::format("{}{}{}{}{}", std::get<0>(last), std::get<1>(last), std::get<2>(last), std::get<3>(last), '\n'); }
輸出
long
[編輯] 參見
返回指向起始的迭代器 (公開成員函式) | |
(C++20) |
返回指示範圍末尾的哨兵 (定製點物件) |