std::basic_string<CharT,Traits,Allocator>::rbegin, std::basic_string<CharT,Traits,Allocator>::crbegin
Материал из cppreference.com
< cpp | string | basic string
(1) | ||
reverse_iterator rbegin(); |
(до C++11) | |
reverse_iterator rbegin() noexcept; |
(начиная с C++11) (до C++20) |
|
constexpr reverse_iterator rbegin() noexcept; |
(начиная с C++20) | |
(2) | ||
const_reverse_iterator rbegin() const; |
(до C++11) | |
const_reverse_iterator rbegin() const noexcept; |
(начиная с C++11) (до C++20) |
|
constexpr const_reverse_iterator rbegin() const noexcept; |
(начиная с C++20) | |
(3) | ||
const_reverse_iterator crbegin() const; |
(до C++11) | |
const_reverse_iterator crbegin() const noexcept; |
(начиная с C++11) (до C++20) |
|
constexpr const_reverse_iterator crbegin() const noexcept; |
(начиная с C++20) | |
Возвращает обратный итератор на первый символ перевёрнутой строки. Он соответствует последнему символу неперевёрнутой строки.
Содержание |
[править] Параметры
(нет)
[править] Возвращаемое значение
Обратный итератор на первый символ.
[править] Сложность
Константная.
[править] Примечание
В libstdc++, crbegin()
недоступна в режиме C++98.
[править] Пример
Запустить этот код
#include <algorithm> #include <iostream> #include <iterator> #include <string> int main() { std::string s("Exemplar!"); *s.rbegin() = 'y'; std::cout << s << '\n'; // "Exemplary" std::string c; std::copy(s.crbegin(), s.crend(), std::back_inserter(c)); std::cout << c << '\n'; // "yralpmexE" }
Вывод:
Exemplary yralpmexE
[править] Отчёты о дефектах
Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:
Номер | Применён | Поведение в стандарте | Корректное поведение |
---|---|---|---|
LWG 1192 | C++98 | std::basic_string не имеет функцию-элемент crbegin()
|
добавлена |
[править] Смотрите также
(DR*) |
возвращает обратный итератор на конец (public функция-элемент) |
(C++17) |
возвращает обратный итератор на начало (public функция-элемент std::basic_string_view<CharT,Traits> )
|