iter_swap(ranges::concat_view::iterator)
来自 cppreference.cn
< cpp | ranges | concat view | iterator
friend constexpr void iter_swap( const /*iterator*/& x, const /*iterator*/& y ) noexcept( /* see description */ ) requires ( /* see description */ ); |
(自 C++26 起) | |
交换 x 和 y 的底层迭代器所指向的对象。等价于 std::visit
(
[&](const auto& it1, const auto& it2)
{
if constexpr (std::is_same_v<decltype(it1), decltype(it2)>)
ranges::iter_swap(it1, it2);
else
ranges::swap(*x, *y);
},
x.it_
,
y.it_
);
requires 子句中的表达式等价于 std::swappable_with<std::iter_reference_t</*iterator*/>,
std::iter_reference_t</*iterator*/>> &&
(... && std::indirectly_swappable<ranges::iterator_t<maybe-const
<Const, Views>>>) 。
如果 x.it_
.valueless_by_exception() || y.it_
.valueless_by_exception() 为 true,则行为未定义。
此函数对于普通的非限定或限定查找不可见,并且只有当 concat_view::iterator
<Const> 是参数的关联类时,才能通过实参依赖查找找到。
内容 |
[编辑] 参数
x, y | - | 迭代器 |
[编辑] 异常
设 its 为左值包,其中每个值都是 const ranges::iterator_t<maybe-const
<Const, Views>> 中对应类型的。
noexcept 规范:
noexcept(noexcept(ranges::swap(*x, *y)) && ... && noexcept(ranges::iter_swap(its, its)))
[编辑] 示例
此章节不完整 原因:没有示例 |
[编辑] 参见
(C++20) |
交换两个可解引用对象所引用的值 (定制点对象) |
交换两个迭代器所指向的元素 (函数模板) |