std::common_iterator<I,S>::operator*,->
来自cppreference.com
| |
(1) | (C++20 起) |
| |
(2) | (C++20 起) |
| |
(3) | (C++20 起) |
| 辅助类型 |
||
| |
(4) | (仅用于阐述*) |
返回指向当前元素的指针或引用,或保有它的代理。
令 it 代表 var 所保有的 I 类型迭代器,即 std::get<I>(var )。
1,2) 返回解引用
it 的结果。3) 返回指向当前元素的指针或底层迭代器,或保有它的代理:
- 如果
I是指针类型或表达式it.operator->()良构,那么等价于return it;。 - 否则,如果
std::iter_reference_t<I>是引用类型,那么等价于auto&& tmp = *it; return std::addressof(tmp);。 - 否则等价于
return /*proxy*/(*it);。
requires 子句中的表达式等价于
std::indirectly_readable<const I> && ( requires(const I& i) { i.operator->(); } || std::is_reference_v<std::iter_reference_t<I>> || std::constructible_from<std::iter_value_t<I>, std::iter_reference_t<I>> )。|
如果 |
(C++26 前) |
|
如果 |
(C++26 起) |
返回值
1,2) 到当前元素的引用或纯右值临时量。等价于
*it。3) 前述的指向当前元素的指针或迭代器,或保有它的代理。
示例
运行此代码
#include <complex>
#include <initializer_list>
#include <iostream>
#include <iterator>
using std::complex_literals::operator""i;
int main()
{
const auto il = {1i, 3.14 + 2i, 3i, 4i, 5i};
using CI = std::common_iterator<std::counted_iterator<decltype(il)::iterator>,
std::default_sentinel_t>;
CI ci{std::counted_iterator{std::next(begin(il), 1), std::ssize(il) - 1}};
std::cout << *ci << ' ' << ci->real() << '\n';
}
输出:
(3.14,2) 3.14
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
| 缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
|---|---|---|---|
| LWG 3574 | C++20 | variant 为完全 constexpr (P2231R1) 但 common_iterator 不是
|
亦使之为 constexpr |
| LWG 3595 | C++20 | 代理类型的函数缺少 constexpr 与 noexcept | 已添加 |
| LWG 3672 | C++20 | operator-> 可以在常用情况下按引用返回
|
始终按值返回 |
参阅
构造新的 common_iterator (公开成员函数) |