命名空间
变体
操作

std::counted_iterator<I>::operator*,->

来自 cppreference.com
 
 
迭代器库
迭代器概念
迭代器原语
算法概念和实用程序
间接可调用概念
常见算法要求
(C++20)
(C++20)
(C++20)
实用程序
(C++20)
迭代器适配器
范围访问
(C++11)(C++14)
(C++14)(C++14)  
(C++11)(C++14)
(C++14)(C++14)  
(C++17)(C++20)
(C++17)
(C++17)
 
 
constexpr decltype(auto) operator*();
(1) (自 C++20 起)
constexpr decltype(auto) operator*() const
    requires /*dereferenceable*/<const I>;
(2) (自 C++20 起)
constexpr auto operator->() const noexcept
    requires std::contiguous_iterator<I>;
(3) (自 C++20 起)
1,2) 返回对当前元素的引用。如果 this->count() <= 0,则行为未定义。函数体等效于 return *current;.
3) 返回指向当前元素的指针。函数体等效于 return std::to_address(current);.

内容

[编辑] 参数

(无)

[编辑] 返回值

对当前元素的引用或指针。

[编辑] 示例

#include <complex>
#include <iostream>
#include <iterator>
using std::operator""i;
 
int main()
{
    const auto il = {1.i, 2.i, 3.i, 4.i, 5.i};
 
    for (std::counted_iterator i{il.begin() + 1, 3}; i != std::default_sentinel; ++i)
        std::cout << *i << ' ';
    std::cout << '\n';
 
    for (std::counted_iterator i{il.begin() + 1, 3}; i != std::default_sentinel; ++i)
        std::cout << i->imag() << ' ';
    std::cout << '\n';
}

输出

(0,2) (0,3) (0,4)
2 3 4

[编辑] 参见

按索引访问元素
(公共成员函数) [编辑]