std::basic_string<CharT,Traits,Allocator>::begin, std::basic_string<CharT,Traits,Allocator>::cbegin

来自cppreference.com
< cpp‎ | string‎ | basic string
 
 
 
std::basic_string
成员函数
元素访问
迭代器
basic_string::beginbasic_string::cbegin
容量
操作
搜索
常量
推导指引 (C++17)
非成员函数
I/O
比较
(C++20 前)(C++20 前)(C++20 前)(C++20 前)(C++20 前)(C++20)
数值转换
(C++11)(C++11)(C++11)
(C++11)(C++11)    
(C++11)(C++11)(C++11)
(C++11)
(C++11)
辅助类
 
(1)
iterator begin();
(C++11 前)
iterator begin() noexcept;
(C++11 起)
(C++20 前)
constexpr iterator begin() noexcept;
(C++20 起)
(2)
const_iterator begin() const;
(C++11 前)
const_iterator begin() const noexcept;
(C++11 起)
(C++20 前)
constexpr const_iterator begin() const noexcept;
(C++20 起)
(3)
const_iterator cbegin() const;
(C++11 前)
const_iterator cbegin() const noexcept;
(C++11 起)
(C++20 前)
constexpr const_iterator cbegin() const noexcept;
(C++20 起)

返回指向字符串首字符的迭代器。

begin() 返回可变迭代器,取决于 *this 的常量性。

cbegin() 始终返回迭代器。它等价于 const_cast<const basic_string&>(*this).begin()

range-begin-end.svg

参数

(无)

返回值

指向首字符的迭代器。

复杂度

常数。

注解

在 libstdc++ 中,cbegin() 不能在 C++98 模式中使用。

示例

#include <iostream>
#include <string>
 
int main()
{
    std::string s("Exemplar");
    *s.begin() = 'e';
    std::cout << s <<'\n';
 
    auto i = s.cbegin();
    std::cout << *i << '\n';
//  *i = 'E'; // 错误: i 是常迭代器
}

输出:

exemplar
e

缺陷报告

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

缺陷报告 应用于 出版时的行为 正确行为
LWG 1192 C++98 std::string 没有成员函数 cbegin() 已添加

参阅

返回指向末尾的迭代器
(公开成员函数)
返回指向起始位置的迭代器
(std::basic_string_view<CharT,Traits> 的公开成员函数)