basic_string::operator[]
Предоставляет ссылку на символ с указанным индексом в строке.
const_reference operator[](
size_type _Off
) const;
reference operator[](
size_type _Off
);
Параметры
- _Off
Индекс позиции элемента, на которую.
Возвращаемое значение
Ссылку на символ в позиции строки указанной индексом параметра.
Заметки
Первый элемент с нуля индекс строки и следующие элементы индексируются последовательно положительным целым числом, чтобы строка длины n будет иметь nth элемент индексный числом n - 1.
operator[] быстрее, чем функцию-член в для прочитанного предоставляемые и записи к элементам строки.
operator[] не проверяет, является ли индекс передан как параметр допустим, но функцию-член at выполняет и поэтому должен использоваться в соответствие не обязательно. Недопустимый индекс (индекс менее, ноль или более больше или равно размеру строки), переданный функции-члену at создает исключение класс out_of_range. Недопустимый индекс передал в operator[] результаты не в определенном расширения функциональности, но индекс равный с длиной строки допустимый индекс для строк const и оператор возвращает нуль-символ, этим индексом.
Возвращаемая ссылка может быть аннулированы перераспределениями или изменениями строки, для строк const.
При компилировании с _SECURE_SCL 1, ошибка во время выполнения возникает при попытке получить элемент за пределами границ строки. Дополнительные сведения см. в разделе Проверяемые итераторы.
Пример
// basic_string_op_ref.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
string str1 ( "Hello world" ), str2 ( "Goodbye world" );
const string cstr1 ( "Hello there" ), cstr2 ( "Goodbye now" );
cout << "The original string str1 is: " << str1 << endl;
cout << "The original string str2 is: " << str2 << endl;
// Element access to the non-const strings
basic_string <char>::reference refStr1 = str1 [6];
basic_string <char>::reference refStr2 = str2.at ( 3 );
cout << "The character with an index of 6 in string str1 is: "
<< refStr1 << "." << endl;
cout << "The character with an index of 3 in string str2 is: "
<< refStr2 << "." << endl;
// Element access to the const strings
basic_string <char>::const_reference crefStr1 = cstr1 [ cstr1.length ( ) ];
basic_string <char>::const_reference crefStr2 = cstr2.at ( 8 );
if ( crefStr1 == '\0' )
cout << "The null character is returned as a valid reference."
<< endl;
else
cout << "The null character is not returned." << endl;
cout << "The character with index of 8 in the const string cstr2 is: "
<< crefStr2 << "." << endl;
}
Output
The original string str1 is: Hello world
The original string str2 is: Goodbye world
The character with an index of 6 in string str1 is: w.
The character with an index of 3 in string str2 is: d.
The null character is returned as a valid reference.
The character with index of 8 in the const string cstr2 is: n.
Требования
Заголовок:<string>
Пространство имен: std