名稱空間
變體
操作

std::iterator_traits<std::counted_iterator>

來自 cppreference.com
 
 
迭代器庫
迭代器概念
迭代器原語
演算法概念與工具
間接可呼叫概念
常用演算法要求
工具
迭代器介面卡
範圍訪問
(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 /* 見下文 */
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-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_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++ 標準。

缺陷報告 應用於 釋出時的行為 正確的行為
P2259R1 C++20 沒有 requires-clause
pointer 無條件定義為 void
添加了約束

[編輯] 參閱

提供迭代器屬性的統一介面
(類模板)