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++ 关键词
std::bidirectional_iterator
concept bidirectional_iterator =
std::forward_iterator<I> &&
std::derived_from</*ITER_CONCEPT*/<I>, std::bidirectional_iterator_tag> &&
requires(I i) {
{ --i } -> std::same_as<I&>;
{ i-- } -> std::same_as<I>;
概念 bidirectional_iterator
细化 forward_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> 不指代类型并导致替换失败。
语义要求
称双向迭代器 r
可自减,若且唯若存在某个 s
使得 ++s == r 。
bidirectional_iterator<I>
得到实现,仅若其所蕴含的概念均被实现,且给定二个 I
类型对象 a
与 b
:
- 若
a
可自减,则a
在表达式 --a 与 a-- 的定义域中。 - 前自减生成指代运算数的左值: std::addressof(--a) == std::addressof(a) ;
- 后自减生成运算数先前的值:若 bool(a == b) ,则 bool(a-- == b) 。
- 后自减和前自减在运算数上进行相同操作:若 bool(a == b) ,则求值
a--
与--b
两者后, bool(a == b) 仍然成立。 - 自增和自减互逆:
- 若
a
可自增且 bool(a == b) ,则 bool(--(++a) == b) 。 - 若
a
可自减且 bool(a == b) ,则 bool(--(++a) == b) 。
- 若
相等性保持
若表达式对给定的相等输入产生相等输出,则它保持相等性。
- 表达式的输入由其操作数组成。
- 表达式的输出由其结果和表达式所修改的所有操作数(若存在)组成。
在标准概念的规范中,操作数定义为仅包含下列内容的最大子表达式:
- 标识表达式,及
- 对 std::move 、 std::forward 与 std::declval 的调用。
每个操作数的 cv 限定与值类别,是通过假设每个模板类型形参代表一个 cv 无限定的非数组对象类型确定的。
进一步要求每个要求保持相等性的表达式都稳定:这种表达式带相同输入对象的二次求值必须拥有相等的输出,而无任何对这些输入对象的显式中间修改。
除非另外提醒,每个用于 requires 表达式中的表达式都要求保持相等性且稳定,而表达式的求值必须只修改其非常操作数。必须不修改常操作数。
参阅
(C++20) |
指定 input_iterator 为向前迭代器,支持相等比较与多趟操作 (概念) |