C++ åèæå
- C++11
- C++14
- C++17
- C++20
- C++ ç¼è¯å¨æ¯ææ åµè¡¨
- ç¬ç«ä¸å®¿ä¸»å®ç°
- C++ è¯è¨
- C++ å ³é®è¯
- é¢å¤çå¨
- C++ æ ååºå¤´æä»¶
- å ·åè¦æ±
- åè½ç¹æ§æµè¯ (C++20)
- å·¥å ·åº
- ç±»åæ¯æï¼åºæ¬ç±»åãRTTIãç±»åç¹æ§ï¼
- æ¦å¿µåº (C++20)
- é误å¤ç
- 卿å å管ç
- æ¥æåæ¶é´å·¥å ·
- å符串åº
- 容å¨åº
- è¿ä»£å¨åº
- std::begin, std::cbegin
- std::end, std::cend
- std::next
- std::reverse_iterator
- std::rbegin, std::crbegin
- std::indirectly_readable
- std::indirectly_writable
- std::weakly_incrementable
- std::prev
- std::move_iterator
- std::size, std::ssize
- std::empty
- std::data
- std::insert_iterator
- std::rend, std::crend
- std::incrementable
- std::input_or_output_iterator
- std::sentinel_for
- std::sized_sentinel_for, std::disable_sized_sentinel_for
- std::input_iterator
- std::output_iterator
- std::forward_iterator
- std::bidirectional_iterator
- std::random_access_iterator
- std::contiguous_iterator
- std::iterator_traits
- std::input_iterator_tag, std::output_iterator_tag, std::forward_iterator_tag, std::bidirectional_iterator_tag, std::random_access_iterator_tag, std::contiguous_iterator_tag
- std::iterator
- std::incrementable_traits
- std::indirectly_readable_traits
- std::iter_value_t, std::iter_reference_t, std::iter_difference_t, std::iter_rvalue_reference_t, std::iter_common_reference_t
- std::indirect_unary_invocable, std::indirectly_regular_unary_invocable
- std::indirect_unary_predicate
- std::indirect_binary_predicate
- std::indirect_equivalence_relation
- std::indirect_strict_weak_order
- std::indirectly_movable
- std::indirectly_movable_storable
- std::indirectly_copyable
- std::indirectly_copyable_storable
- std::indirectly_swappable
- std::indirectly_comparable
- std::permutable
- std::mergeable
- std::sortable
- std::indirect_result_t
- std::projected
- std::move_sentinel
- std::back_insert_iterator
- std::front_insert_iterator
- std::make_reverse_iterator
- std::make_move_iterator
- std::default_sentinel_t, std::default_sentinel
- std::unreachable_sentinel_t, std::unreachable_sentinel
- std::back_inserter
- std::front_inserter
- std::inserter
- std::istream_iterator
- std::ostream_iterator
- std::istreambuf_iterator
- std::ostreambuf_iterator
- std::advance
- std::distance
- 注é
- èå´åº (C++20)
- ç®æ³åº
- æ°å¼åº
- è¾å ¥/è¾åºåº
- æä»¶ç³»ç»åº
- æ¬å°ååº
- æ£å表达å¼åº
- ååæä½åº
- çº¿ç¨æ¯æåº
- å®éªæ§ C++ ç¹æ§
- æç¨çèµæº
- ç´¢å¼
- std 符å·ç´¢å¼
- åç¨æ¯æ (C++20)
- C++ å ³é®è¯
ä½ç½®ï¼é¦é¡µ > C++ åèæå >è¿ä»£å¨åº > std::iterator_traits
std::iterator_traits
| å®ä¹äºå¤´æä»¶ <iterator>
|
||
| template< class Iter > struct iterator_traits; |
||
| template< class T > struct iterator_traits<T*>; |
||
| template< class T > struct iterator_traits<const T*>; |
(C++20 å) | |
std::iterator_traits æ¯ç±»åç¹æ§ç±»ï¼ä¸ºè¿ä»£å¨ç±»åç屿§æä¾ç»ä¸çæ¥å£ï¼ä½¿å¾è½å¤ä»
é对è¿ä»£å¨å®ç°ç®æ³ã
该类å®ä¹äºå¦ä¸ç±»åï¼ä¸ std::iterator ä¸çç±»åå®ä¹ç¸å¯¹åºï¼
-
difference_type- å¯ç¨æ¥æ è¯è¿ä»£å¨é´è·ç¦»çæç¬¦å·æ´æ°ç±»å -
value_type- è¿ä»£å¨è§£é¤å¼ç¨åæå¾å°çå¼çç±»åã对äºè¾åºè¿ä»£å¨ï¼è¯¥ç±»å为voidã -
pointer- æå被è¿ä»£ç±»å (value_type) çæé -
reference- 被è¿ä»£ç±»å (value_type) çå¼ç¨ç±»å -
iterator_category- è¿ä»£å¨ç±»å«ãå¿ é¡»æ¯è¿ä»£å¨ç±»å«æ ç¾ä¹ä¸ã
å¯ä»¥éå¯¹ç¨æ·èªå®ä¹è¿ä»£å¨ç¹å该模çï¼è¿æ ·ï¼å³ä¾¿è¯¥ç±»å没ææä¾ä¸è¬çç±»åå®ä¹ï¼ä¹è½è·åå ³äºè¯¥è¿ä»£å¨çä¿¡æ¯ã
模çå½¢å
| Iter | - | éè¦åå¾ä¸ä¹ç¸å ³å±æ§çè¿ä»£å¨ç±»å |
æåç±»å
| Â | |
| æåç±»å | å®ä¹ |
difference_type
|
Iter::difference_type
|
value_type
|
Iter::value_type
|
pointer
|
Iter::pointer
|
reference
|
Iter::reference
|
iterator_category
|
Iter::iterator_category
|
|
è¥ |
(C++17 èµ·) (C++20 å) | ||||||||||||||||||||||||||||||||||||||||||
|
è¥
å¦åï¼è¥
å¦åï¼è¥
å¦åï¼æ¤æ¨¡æ¿æ 任使è¿äºåç§°çæåæ¤æ¨¡æ¿æ 任使é£äºåç§°çæåï¼ std::iterator_traits 对 SFINAE å好ï¼ã |
(C++20 èµ·) | ||||||||||||||||||||||||||||||||||||||||||
ç¹å
å¦æè¦æç¨æ·æä¾çç±»åä½ä¸ºè¿ä»£å¨ä½¿ç¨ï¼è¯¥ç±»åç¹å¾å¯ä»¥é对è¿ä¸ç±»åè¿è¡ç¹åãæ ååºä¸æä¾äºé对æéç±»å T * ç两ç§åç¹åï¼ä½¿å¾å¯ä»¥å¨ä»»ä½éè¦è¿ä»£å¨çç®æ³é使ç¨è£¸æéã
T * ç¹åæåç±»å
|
ä»
è¥ std::is_object_v<T> 为 |
(C++20 èµ·) |
| Â | |
| æåç±»å | å®ä¹ |
difference_type
|
std::ptrdiff_t |
value_type
|
T (C++20 å)std::remove_cv_t<T> (C++20 èµ·)
|
pointer
|
T*
|
reference
|
T&
|
iterator_category
|
std::random_access_iterator_tag |
iterator_concept(C++20 èµ·)
|
std::contiguous_iterator_tag |
|
|||||||||||||||
| Â | |
| æåç±»å | å®ä¹ |
difference_type
|
std::ptrdiff_t |
value_type
|
T
|
pointer
|
const T*
|
reference
|
const T&
|
iterator_category
|
std::random_access_iterator_tag |
示ä¾
ä¸å使ç¨å±ç¤ºå¯¹ååè¿ä»£å¨çéç¨ reverse() å®ç°
#include <iostream> #include <iterator> #include <vector> #include <list>  template<class BidirIt> void my_reverse(BidirIt first, BidirIt last) { typename std::iterator_traits<BidirIt>::difference_type n = std::distance(first, last); --n; while(n > 0) { typename std::iterator_traits<BidirIt>::value_type tmp = *first; *first++ = *--last; *last = tmp; n -= 2; } }  int main() { std::vector<int> v{1, 2, 3, 4, 5}; my_reverse(v.begin(), v.end()); for (int n : v) { std::cout << n << ' '; } std::cout << '\n';  std::list<int> l{1, 2, 3, 4, 5}; my_reverse(l.begin(), l.end()); for (auto n : l) { std::cout << n << ' '; } std::cout << '\n';  int a[] = {1, 2, 3, 4, 5}; my_reverse(a, a+5); for (int i=0; i<5; ++i) { std::cout << a[i] << ' '; } std::cout << '\n';  // std::istreambuf_iterator<char> i1(std::cin), i2; // my_reverse(i1, i2); // ç¼è¯é误  }
è¾åºï¼
5 4 3 2 1 5 4 3 2 1 5 4 3 2 1
åé
| (C++17 ä¸å¼ç¨) |
ç¨äºç®åç®åçè¿ä»£å¨çå¿
è¦ç±»åå®ä¹çåºç±» (类模æ¿) |
| ç¨äºæç¤ºè¿ä»£å¨ç±»å«ç空类类å (ç±») |