W3cubDocs

/C++

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

(1)
iterator begin();
(until C++11)
iterator begin() noexcept;
(since C++11)
(until C++20)
constexpr iterator begin() noexcept;
(since C++20)
(2)
const_iterator begin() const;
(until C++11)
const_iterator begin() const noexcept;
(since C++11)
(until C++20)
constexpr const_iterator begin() const noexcept;
(since C++20)
(3)
const_iterator cbegin() const noexcept;
(since C++11)
(until C++20)
constexpr const_iterator cbegin() const noexcept;
(since C++20)

Returns an iterator to the first character of the string.

begin() returns a mutable or constant iterator, depending on the constness of *this.

cbegin() always returns a constant iterator. It is equivalent to const_cast<const basic_string&>(*this).begin().

range-begin-end.svg

Parameters

(none).

Return value

Iterator to the first character.

Complexity

Constant.

Example

#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'; // error: i is a constant iterator
}

Output:

exemplar
e

See also

(C++11)
returns an iterator to the end
(public member function)
(C++17)
returns an iterator to the beginning
(public member function of std::basic_string_view<CharT,Traits>)

© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/string/basic_string/begin