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::random_access_iterator
std::random_access_iterator
concept random_access_iterator =
std::bidirectional_iterator<I> &&
std::derived_from</*ITER_CONCEPT*/<I>, std::random_access_iterator_tag> &&
std::totally_ordered<I> &&
std::sized_sentinel_for<I, I> &&
requires(I i, const I j, const std::iter_difference_t<I> n) {
{ i += n } -> std::same_as<I&>;
{ j + n } -> std::same_as<I>;
{ n + j } -> std::same_as<I>;
{ i -= n } -> std::same_as<I&>;
{ j - n } -> std::same_as<I>;
{ j[n] } -> std::same_as<std::iter_reference_t<I>>;
æ¦å¿µ random_access_iterator ç»å bidirectional_iterator ï¼æ·»å ç¨ += ã -= ã + å - è¿ç®ç¬¦çå¸¸æ°æ¶é´åè¿ãç¨ - çå¸¸æ°æ¶é´è·ç¦»è®¡ç®ï¼å另䏿 çæ°ç»è®°æ³æ¯æã
ç®å½ |
è¿ä»£å¨æ¦å¿µç¡®å®
æ¤æ¦å¿µçå®ä¹éè¿ä» ç¨äºééçå«åæ¨¡æ¿ /*ITER_CONCEPT*/ 说æã
ä¸ºç¡®å® /*ITER_CONCEPT*/<I> ï¼ä»¤ ITER_TRAITS<I> è¥ç¹å std::iterator_traits<I> ä»ä¸»æ¨¡æ¿çæåæä»£ I ï¼å¦åæä»£ std::iterator_traits<I> ï¼
- è¥ ITER_TRAITS<I>::iterator_concept 忳并æåç±»åï¼å /*ITER_CONCEPT*/<I> æä»£è¯¥ç±»åã
- å¦åï¼è¥ ITER_TRAITS<I>::iterator_category 忳并æåç±»åï¼å /*ITER_CONCEPT*/<I> æä»£è¯¥ç±»åã
- å¦åï¼è¥ std::iterator_traits<I> ä»ä¸»æ¨¡æ¿çæï¼å /*ITER_CONCEPT*/<I> æä»£ std::random_access_iterator_tag ã
- å¦å /*ITER_CONCEPT*/<I> ä¸æä»£ç±»åå¹¶å¯¼è´æ¿æ¢å¤±è´¥ã
è¯ä¹è¦æ±
令 a ä¸ b 为 I ç±»åçåæ³è¿ä»£å¨ï¼ä½¿å¾ä» a 坿µè¾¾ b ï¼å¹¶ä»¤ n 为çäº b - a ç std::iter_difference_t<I> ç±»åå¼ã random_access_iterator<I> ä»
è¥å
¶æè´å«çæ¦å¿µå被å®ç°å¹¶ä¸ç¬¦åä¸åæ¡ä»¶æå¾å°å®ç°ï¼
- (a += n) çäº b ã
- std::addressof(a += n) çäº std::addressof(a) ã
- (a + n) çäº (a += n) ã
- (a + n) çäº (n + a) ã
- 对äºä»»ä½äºä¸ªæ£æ´æ°
xä¸yï¼è¥ a + (x + y) åæ³ï¼å a + (x + y) çäº (a + x) + y ã - a + 0 çäº a ã
- è¥ (a + (n - 1)) åæ³ï¼å --b çäº (a + (n - 1)) ã
- (b += -n) ä¸ (b -= n) é½çäº a ã
- std::addressof(b -= n) çäº std::addressof(b) ã
- (b - n) çäº (b -= n) ã
- è¥ b å¯è§£å¼ç¨ï¼å a[n] 忳并çäº *b ã
- bool(a <= b) 为 true ã
- æ¯ä¸ªè¦æ±çæä½åæ¥æå¸¸æ°æ¶é´å¤æåº¦ã
ç¸çæ§ä¿æ
è¥è¡¨è¾¾å¼å¯¹ç»å®çç¸çè¾å ¥äº§çç¸çè¾åºï¼åå®ä¿æç¸çæ§ã
- 表达å¼çè¾å ¥ç±å ¶æä½æ°ç»æã
- 表达å¼çè¾åºç±å ¶ç»æåè¡¨è¾¾å¼æä¿®æ¹çæææä½æ°ï¼è¥åå¨ï¼ç»æã
卿 åæ¦å¿µçè§èä¸ï¼æä½æ°å®ä¹ä¸ºä» å å«ä¸åå 容çæå¤§å表达å¼ï¼
- æ è¯è¡¨è¾¾å¼ï¼å
- 对 std::move ã std::forward ä¸ std::declval çè°ç¨ã
æ¯ä¸ªæä½æ°ç cv éå®ä¸å¼ç±»å«ï¼æ¯éè¿å设æ¯ä¸ªæ¨¡æ¿ç±»åå½¢å代表ä¸ä¸ª cv æ éå®çéæ°ç»å¯¹è±¡ç±»åç¡®å®çã
è¿ä¸æ¥è¦æ±æ¯ä¸ªè¦æ±ä¿æç¸çæ§ç表达å¼é½ç¨³å®ï¼è¿ç§è¡¨è¾¾å¼å¸¦ç¸åè¾å ¥å¯¹è±¡çäºæ¬¡æ±å¼å¿ é¡»æ¥æç¸ççè¾åºï¼èæ ä»»ä½å¯¹è¿äºè¾å ¥å¯¹è±¡çæ¾å¼ä¸é´ä¿®æ¹ã
é¤éå¦å¤æéï¼æ¯ä¸ªç¨äº requires 表达å¼ä¸ç表达å¼é½è¦æ±ä¿æç¸çæ§ä¸ç¨³å®ï¼è表达å¼çæ±å¼å¿ é¡»åªä¿®æ¹å ¶é常æä½æ°ãå¿ é¡»ä¸ä¿®æ¹å¸¸æä½æ°ã
éå¼è¡¨è¾¾å¼åç§
使ç¨ä¸ä¿®æ¹æ const å·¦å¼è¿ç®æ°ç表达å¼ç requires 表达å¼äº¦éå¼è¦æ±è¯¥è¡¨è¾¾å¼çé¢å¤åç§å¯¹ç»å®è¿ç®æ°æ¥åé const 左弿ï¼å¯ä¸º const çï¼å³å¼ï¼é¤é以æåºå«çè¯ä¹æ¾å¼è¦æ±è¿ç§è¡¨è¾¾å¼åç§ãè¿äºéå¼è¡¨è¾¾å¼åç§å¿ 须符åä¸å£°æç表达å¼çç¸åçè¯ä¹ã䏿å®å®ç°ä»¥ä½ç§ç¨åº¦æ ¡éªåç§çè¯æ³ã
åé
| (C++20) |
æå® forward_iterator 为ååè¿ä»£å¨ï¼æ¯æååç§»å¨ (æ¦å¿µ) |