std::iterator_traits<std::counted_iterator>
在头文件 <iterator> 中定义 |
||
template< std::input_iterator I > requires /* see below */ |
(自 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_iterator 和 std::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 |
添加了约束 |
[编辑] 另请参阅
为迭代器的属性提供统一的接口 (类模板) |