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::contiguous_iterator
std::contiguous_iterator
concept contiguous_iterator =
std::random_access_iterator<I> &&
std::derived_from</*ITER_CONCEPT*/<I>, std::contiguous_iterator_tag> &&
std::is_lvalue_reference_v<std::iter_reference_t<I>> &&
std::same_as<
std::iter_value_t<I>, std::remove_cvref_t<std::iter_reference_t<I>>
> &&
requires(const I& i) {
{ std::to_address(i) } ->
std::same_as<std::add_pointer_t<std::iter_reference_t<I>>>;
contiguous_iterator æ¦å¿µç»å random_access_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 ç±»åçå¯è§£å¼ç¨è¿ä»£å¨ï¼ c 为 I ç±»åçä¸å¯è§£å¼ç¨è¿ä»£å¨ï¼ä½¿å¾ b ä» a 坿µè¾¾è c ä» b 坿µè¾¾ãç±»å I å®ç° contiguous_iterator ä»
è¥å
¶æè´å«çæææ¦å¿µå被å®ç°ï¼ä¸ï¼
- std::to_address(a) == std::addressof(*a) ï¼
- std::to_address(b) == std::to_address(a) + std::iter_difference_t<I>(b - a) ï¼å¹¶ä¸
- std::to_address(c) == std::to_address(a) + std::iter_difference_t<I>(c - a) ã
ç¸çæ§ä¿æ
è¥è¡¨è¾¾å¼å¯¹ç»å®çç¸çè¾å ¥äº§çç¸çè¾åºï¼åå®ä¿æç¸çæ§ã
- 表达å¼çè¾å ¥ç±å ¶æä½æ°ç»æã
- 表达å¼çè¾åºç±å ¶ç»æåè¡¨è¾¾å¼æä¿®æ¹çæææä½æ°ï¼è¥åå¨ï¼ç»æã
卿 åæ¦å¿µçè§èä¸ï¼æä½æ°å®ä¹ä¸ºä» å å«ä¸åå 容çæå¤§å表达å¼ï¼
- æ è¯è¡¨è¾¾å¼ï¼å
- 对 std::move ã std::forward ä¸ std::declval çè°ç¨ã
æ¯ä¸ªæä½æ°ç cv éå®ä¸å¼ç±»å«ï¼æ¯éè¿å设æ¯ä¸ªæ¨¡æ¿ç±»åå½¢å代表ä¸ä¸ª cv æ éå®çéæ°ç»å¯¹è±¡ç±»åç¡®å®çã
è¿ä¸æ¥è¦æ±æ¯ä¸ªè¦æ±ä¿æç¸çæ§ç表达å¼é½ç¨³å®ï¼è¿ç§è¡¨è¾¾å¼å¸¦ç¸åè¾å ¥å¯¹è±¡çäºæ¬¡æ±å¼å¿ é¡»æ¥æç¸ççè¾åºï¼èæ ä»»ä½å¯¹è¿äºè¾å ¥å¯¹è±¡çæ¾å¼ä¸é´ä¿®æ¹ã
é¤éå¦å¤æéï¼æ¯ä¸ªç¨äº requires 表达å¼ä¸ç表达å¼é½è¦æ±ä¿æç¸çæ§ä¸ç¨³å®ï¼è表达å¼çæ±å¼å¿ é¡»åªä¿®æ¹å ¶é常æä½æ°ãå¿ é¡»ä¸ä¿®æ¹å¸¸æä½æ°ã
éå¼è¡¨è¾¾å¼åç§
使ç¨ä¸ä¿®æ¹æ const å·¦å¼è¿ç®æ°ç表达å¼ç requires 表达å¼äº¦éå¼è¦æ±è¯¥è¡¨è¾¾å¼çé¢å¤åç§å¯¹ç»å®è¿ç®æ°æ¥åé const 左弿ï¼å¯ä¸º const çï¼å³å¼ï¼é¤é以æåºå«çè¯ä¹æ¾å¼è¦æ±è¿ç§è¡¨è¾¾å¼åç§ãè¿äºéå¼è¡¨è¾¾å¼åç§å¿ 须符åä¸å£°æç表达å¼çç¸åçè¯ä¹ã䏿å®å®ç°ä»¥ä½ç§ç¨åº¦æ ¡éªåç§çè¯æ³ã
注解
æ¯ä¸ªæå宿´å¯¹è±¡ç±»åçæéç±»åé½å®ç° contiguous_iterator ã
æ ååºä¸ï¼å¨ C++17 è¢«è¦æ±æ»¡è¶³éçè¿ç»è¿ä»£å¨ (LegacyContiguousIterator) è¦æ±çè¿ä»£å¨ç±»åï¼äº¦å¨ C++20 ä¸è¢«è¦æ±å®ç° contiguous_iterator ã
åé
| (C++20) |
æå® bidirectional_iterator ä¸ºéæºè®¿é®è¿ä»£å¨ï¼æ¯æå¸¸æ°æ¶é´å
çåè¿å䏿 è®¿é® (æ¦å¿µ) |