std::experimental::ranges::iterator_category
來自 cppreference.com
< cpp | experimental | ranges
定義於標頭檔案 <experimental/ranges/iterator> |
||
template< class I > struct iterator_category {}; |
(1) | |
template< class T > struct iterator_category<T*>; |
(2) | |
template< class T > struct iterator_category<const T> : iterator_category<T> {}; |
(3) | |
template< class T > requires requires { typename T::iterator_category; } |
(4) | |
計算類 `I` 的迭代器類別(如果存在)。使用者可以為程式定義的型別特化 `iterator_category`。
1) 主模板是一個空結構體。
2) 指標的特化。如果 `T` 是一個物件型別,則提供一個成員型別 `type` 等於 `ranges::random_access_iterator_tag`。否則,沒有成員 `type`。
3) const 限定型別的特化。
4) 為定義了公共且可訪問的成員型別 `iterator_category` 的型別進行特化。如果 `T::iterator_category` 與 `std` 名稱空間中的某個迭代器類別標籤相同或派生自該標籤,它將被對映到 `ranges` 名稱空間中對應的標籤,如下所述。否則,提供一個成員型別 `type` 等於 `T::iterator_category`。
- 如果 `T::iterator_category` 與 std::random_access_iterator_tag 相同或派生自它,則提供一個成員型別 `type` 等於 ranges::random_access_iterator_tag。
- 否則,如果 `T::iterator_category` 與 std::bidirectional_iterator_tag 相同或派生自它,則提供一個成員型別 `type` 等於 ranges::bidirectional_iterator_tag。
- 否則,如果 `T::iterator_category` 與 std::forward_iterator_tag 相同或派生自它,則提供一個成員型別 `type` 等於 ranges::forward_iterator_tag。
- 否則,如果 `T::iterator_category` 與 std::input_iterator_tag 相同或派生自它,則提供一個成員型別 `type` 等於 ranges::input_iterator_tag。
- 否則,如果 `T::iterator_category` 與 std::output_iterator_tag 相同或派生自它,則沒有成員 `type`。
[編輯] 輔助別名模板
template< class T > using iterator_category_t = typename ranges::iterator_category<T>::type; |
(ranges TS) | |
[編輯] 示例
本節不完整 原因:無示例 |
[編輯] 參閱
用於指示迭代器類別的空類型別 (類) | |
用於指示迭代器類別的空類型別 (類) | |
收集迭代器相關型別的相容性特徵類 (別名模板) |