跳到主要内容

std::string begin()/cbegin() 方法

// Nonconst version
constexpr iterator begin() noexcept;

// Const version
constexpr const_iterator begin() const noexcept;
constexpr const_iterator cbegin() const noexcept;

返回指向数组末尾之后元素的迭代器

指向字符串的第一个元素。

如果数组为空,返回的迭代器将等于 end()

参数

(无)

返回值

指向第一个元素的迭代器。

复杂度

常数 - O(1)

备注

对于容器c,表达式*c.begin()等效于c.front()

begin 和 cbegin 的区别

对于 const 容器 c,begin 和 cbegin 是相同的 - c.begin() == c.cbegin()

对于非常量类型c的容器,它们返回不同的迭代器

#include <string>

int main()
{
std::string str = "Hello";
auto it = str.begin(); // Type: std::string::iterator
*it = 'J'; // ✔ Ok
}

示例

Main.cpp
#include <string>
#include <iostream>

int main()
{
std::string s("Exemplar");
*s.begin() = 'e';
std::cout << s <<'\n';

auto i = s.cbegin();
std::cout << *i << '\n';
// *i = 'E'; // error: i is a constant iterator
}
输出
exemplar
e
本文源自此 CppReference 页面。它可能因改进或编辑偏好而被修改。点击“编辑此页面”查看本文档的所有更改。
悬停查看原始许可证。

std::string begin()/cbegin() 方法

// Nonconst version
constexpr iterator begin() noexcept;

// Const version
constexpr const_iterator begin() const noexcept;
constexpr const_iterator cbegin() const noexcept;

返回指向数组末尾之后元素的迭代器

指向字符串的第一个元素。

如果数组为空,返回的迭代器将等于 end()

参数

(无)

返回值

指向第一个元素的迭代器。

复杂度

常数 - O(1)

备注

对于容器c,表达式*c.begin()等效于c.front()

begin 和 cbegin 的区别

对于 const 容器 c,begin 和 cbegin 是相同的 - c.begin() == c.cbegin()

对于非常量类型c的容器,它们返回不同的迭代器

#include <string>

int main()
{
std::string str = "Hello";
auto it = str.begin(); // Type: std::string::iterator
*it = 'J'; // ✔ Ok
}

示例

Main.cpp
#include <string>
#include <iostream>

int main()
{
std::string s("Exemplar");
*s.begin() = 'e';
std::cout << s <<'\n';

auto i = s.cbegin();
std::cout << *i << '\n';
// *i = 'E'; // error: i is a constant iterator
}
输出
exemplar
e
本文源自此 CppReference 页面。它可能因改进或编辑偏好而被修改。点击“编辑此页面”查看本文档的所有更改。
悬停查看原始许可证。