命名空间
变体
操作

std::basic_const_iterator

来自 cppreference.cn
 
 
迭代器库
迭代器概念
迭代器原语
算法概念与工具
间接可调用概念
常用算法要求
(C++20)
(C++20)
(C++20)
工具
(C++20)
迭代器适配器
basic_const_iterator
(C++23)
const_iterator
(C++23)
const_sentinel
(C++23)
make_const_iterator
(C++23)
make_const_sentinel
(C++23)

范围访问
(C++11)(C++14)
(C++14)(C++14)  
(C++11)(C++14)
(C++14)(C++14)  
(C++17)(C++20)
(C++17)
(C++17)
 
 
定义于头文件 <iterator>
template< std::input_iterator Iter >
class basic_const_iterator;
(C++23 起)

std::basic_const_iterator 是一个迭代器适配器,其行为与底层迭代器完全相同(底层迭代器必须至少是 LegacyInputIterator 或模型 input_iterator),但解引用会将底层迭代器返回的值转换为不可变。std::basic_const_iterator 的特化是常量迭代器,也就是说,该迭代器永远不能用作输出迭代器,因为不允许修改元素。

目录

[编辑] 成员类型

成员类型 定义
iterator_category
(有条件存在)

如果 Iter 模型为 forward_iterator

否则,没有成员 iterator_category

iterator_concept
value_type std::iter_value_t<Iter>
difference_type std::iter_difference_t<Iter>
reference (私有) std::iter_const_reference_t<Iter>
(仅供说明的成员类型*)

[编辑] 成员对象

成员名称 (Member name) 定义
current (私有) 底层迭代器,base() 从中复制或移动
(仅用于阐释的成员对象*)

[编辑] 成员函数

构造一个新的 basic_const_iterator
(公共成员函数) [编辑]
访问底层迭代器
(公共成员函数) [编辑]
访问指向的元素
(公共成员函数) [编辑]
通过索引访问元素
(公共成员函数) [编辑]
推进或递减迭代器
(公共成员函数) [编辑]
转换为任何常量迭代器,底层迭代器可以转换为该常量迭代器
(公共成员函数) [编辑]
比较底层迭代器
(公共成员函数) [编辑]

[编辑] 非成员函数

比较 basic_const_iterator 与非 basic_const_iterator
(函数模板) [编辑]
推进或递减迭代器
(函数模板) [编辑]
(C++23)
计算两个迭代器适配器之间的距离
(函数模板) [编辑]
(C++23)
将底层迭代器解引用的结果转换为其关联的右值引用类型
(函数) [编辑]

[编辑] 辅助类

确定迭代器和适配的 basic_const_iterator 类型的公共类型
(类模板特化) [编辑]

[编辑] 辅助别名模板

template< std::input_iterator I >
using const_iterator = /* 参见描述 */;
(C++23 起)

如果 I 模型为 constant-iterator(一个仅用于说明的概念),则 const_iterator<I> 表示类型 I。否则为 basic_const_iterator<I>

template< std::semiregular S >
using const_sentinel = /* 参见描述 */;
(C++23 起)

如果 S 模型为 input_iterator,则 const_sentinel<S> 表示类型 const_iterator<S>。否则为 S

[编辑] 辅助函数模板

template< std::input_iterator T >
constexpr const_iterator<T> make_const_iterator( I it ) { return it; }
(C++23 起)
template< std::semiregular S >
constexpr const_sentinel<S> make_const_sentinel( S s ) { return s; }
(C++23 起)

[编辑] 注意

特性测试 标准 特性
__cpp_lib_ranges_as_const 202207L (C++23) std::basic_const_iterator
202311L (C++23)
(DR)
std::basic_const_iterator 应该遵循其底层类型的可转换性

[编辑] 示例

#include <cassert>
#include <iterator>
#include <vector>
 
int main()
{
    std::vector v{1, 2, 3};
    std::vector<int>::iterator i = v.begin();
    *i = 4;   // OK, v[0] == 4 now
    i[1] = 4; // OK, the same as *(i + 1) = 4;
 
    auto ci = std::make_const_iterator(i);
    assert(*ci == 4);   // OK, can read the underlying object
    assert(ci[0] == 4); // OK, ditto
    // *ci = 13;        // Error: location is read-only
    // ci[0] = 13;      // Error: ditto
    ci.base()[0] = 42;  // OK, underlying iterator is writable
    assert(*ci == 42);  // OK, underlying location v[0] was modified
}

[编辑] 缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 发布时的行为 正确的行为
P2836R1 C++23 basic_const_iterator 不遵循其底层类型的可转换性 提供转换操作符