Поделиться через


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 пространство имен:

См. также

Ссылки

basic_string Class