命名空间
变体
操作

std::iterator_traits<std::counted_iterator>

来自 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)
 
 
在头文件 <iterator> 中定义
template< std::input_iterator I >

    requires /* see below */
struct iterator_traits<std::counted_iterator<I>> : std::iterator_traits<I> {
    using pointer = std::conditional_t<std::contiguous_iterator<I>,
                                       std::add_pointer_t<std::iter_reference_t<I>>,
                                       void>;

};
(自 C++20 起)

继承自自定义(从标准部分特化或程序定义的特化生成)std::iterator_traits<I> 的属性,其中成员类型 pointer 已调整,其中 I 模拟 input_iterator

值得注意的是,iterator_concept(如果存在)和 iterator_category 是从 std::iterator_traits<I> 继承的。

requires 子句中的条件当且仅当 std::iterator_traits<I> 不是从主模板生成的时为 true

内容

[编辑] 注意

P2259R1 之前,即使 std::iterator_traits<I> 是从主模板生成的,也会使用此特化。因此,在将 std::counted_iterator<I> 与迭代器概念(例如 forward_iterator)进行比较时,对 /*ITER_CONCEPT*/ 的确定不会考虑 I::iterator_concept,因此 std::counted_iterator<I> 有时会错误地表现为无法模拟该概念。这种不正确的行为在 10.4 之前的 libstdc++ 中实现,以及在 VS 2022 17.0 Preview 3 之前的 MSVC STL 中实现。

标准库为指针类型、std::counted_iteratorstd::common_iterator 提供了 std::iterator_traits 的部分特化。

[编辑] 示例

#include <iterator>
#include <list>
#include <type_traits>
#include <vector>
 
int main()
{
    std::vector v{1, 2, 3, 4};
    std::list l{1, 2, 3, 4};
    std::counted_iterator iv{v.begin(), 3};
    std::counted_iterator il{l.begin(), 3};
    static_assert(std::is_same<int*, std::iterator_traits<decltype(iv)>::pointer>());
    static_assert(std::is_same<void, std::iterator_traits<decltype(il)>::pointer>());
}

[编辑] 缺陷报告

以下更改行为的缺陷报告已追溯应用于以前发布的 C++ 标准。

DR 应用于 已发布的行为 正确行为
P2259R1 C++20 没有 requires 子句
pointer 无条件定义为 void
添加了约束

[编辑] 另请参阅

为迭代器的属性提供统一的接口
(类模板)