std::basic_string<CharT,Traits,Allocator>::front
Материал из cppreference.com
<tbody>
</tbody>
<tbody class="t-dcl-rev t-dcl-rev-num ">
</tbody><tbody>
</tbody>
<tbody class="t-dcl-rev t-dcl-rev-num ">
</tbody><tbody>
</tbody>
| (1) | ||
CharT& front(); |
(до C++20) | |
constexpr CharT& front(); |
(начиная с C++20) | |
| (2) | ||
const CharT& front() const; |
(до C++20) | |
constexpr const CharT& front() const; |
(начиная с C++20) | |
Возвращает ссылку на первый символ строки. Поведение не определено, если empty() равно true.
Параметры
(нет)
Возвращаемое значение
Ссылка на первый символ, эквивалентная operator[](0).
Сложность
Константная.
Примечание
В libstdc++, front() недоступна в режиме C++98.
Пример
Запустить этот код
#include <iostream>
#include <string>
int main()
{
std::string s("Exemplary");
char& f1 = s.front();
f1 = 'e';
std::cout << s << '\n'; // "exemplary"
std::string const c("Exemplary");
char const& f2 = c.front();
std::cout << &f2 << '\n'; // "Exemplary"
}
Вывод:
exemplary
Exemplary
Отчёты о дефектах
Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:
| Номер | Применён | Поведение в стандарте | Корректное поведение |
|---|---|---|---|
| LWG 534 | C++98 | std::basic_string не имеет функцию-элемент front()
|
добавлена |
Смотрите также
(DR*) |
получает доступ к последнему символу (public функция-элемент) |
(C++17) |
предоставляет доступ к первому символу (public функция-элемент std::basic_string_view<CharT,Traits>)
|