std::iterator_traits<std::counted_iterator>
定義於標頭檔案 <iterator> |
||
template< std::input_iterator I > requires /* 見下文 */ |
(C++20 起) | |
繼承自自定義(由標準部分特化或程式定義特化生成)std::iterator_traits<I> 的屬性,並調整成員型別 pointer
,其中 I
建模 input_iterator
。
值得注意的是,iterator_concept
(如果存在)和 iterator_category
繼承自 std::iterator_traits<I>。
requires-clause 中的條件當且僅當 std::iterator_traits<I> 不是由主模板生成時為 true。
目錄 |
[編輯] 注意
在 P2259R1 之前,即使 std::iterator_traits<I> 是由主模板生成的,也會使用此特化。因此,在針對迭代器概念(例如 forward_iterator
)測試 std::counted_iterator<I> 時,/*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++ 標準。
缺陷報告 | 應用於 | 釋出時的行為 | 正確的行為 |
---|---|---|---|
P2259R1 | C++20 | 沒有 requires-clausepointer 無條件定義為 void |
添加了約束 |
[編輯] 參閱
提供迭代器屬性的統一介面 (類模板) |