std::ranges:: cbegin
|
定义于头文件
<ranges>
|
||
|
定义于头文件
<iterator>
|
||
|
inline
namespace
/* 未指定 */
{
inline
constexpr
/* 未指定 */
cbegin
=
/* 未指定 */
;
|
(C++20 起)
(定制点对象) |
|
|
调用签名
|
||
|
template
<
class
T
>
requires
/* 见下文 */
|
(C++20 起) | |
|
返回指向常量限定参数首元素的迭代器。 |
(C++23 前) |
|
返回指向参数首元素的常量迭代器。 |
(C++23 起) |
|
令
对
|
(C++23 前) |
|
若实参为左值或
ranges::
enable_borrowed_range
<
std::
remove_cv_t
<
T
>>
为
true
,则对
所有其他情况下,对
|
(C++23 起) |
返回值类型在所有情况下均满足
std::input_or_output_iterator
和
constant-iterator
(自 C++23 起)
概念。
目录 |
定制点对象
名称
ranges::cbegin
表示一个
定制点对象
,它是一个字面量
semiregular
类类型的常量
函数对象
。详细信息请参阅
定制点对象
。
注释
对于类型为 T 的左值范围 e , ranges :: cbegin ( e ) 等价于
|
ranges:: begin ( std:: as_const ( e ) ) 。 |
(C++23 前) |
|
(C++23 起) |
示例
#include <cassert> #include <ranges> #include <vector> int main() { std::vector v{3, 1, 4}; auto vi = std::ranges::cbegin(v); assert(3 == *vi); ++vi; // 正常:常量迭代器对象是可变的 assert(1 == *vi); // *vi = 13; // 错误:常量迭代器指向不可变元素 int a[]{3, 1, 4}; auto ai = std::ranges::cbegin(a); // cbegin 同样适用于 C 风格数组 assert(3 == *ai and *(ai + 1) == 1); // *ai = 13; // 错误:只读变量不可赋值 }
参见
|
(C++20)
|
返回指向范围起始位置的迭代器
(定制点对象) |
|
(C++11)
(C++14)
|
返回指向容器或数组起始位置的迭代器
(函数模板) |