basic_string::rend
Возвращает итератор, который решает расположение преуспевая последний элемент обратной строке.
const_reverse_iterator rend( ) const;
reverse_iterator rend( );
Возвращаемое значение
Обратный итератор с произвольным доступом, который соответствует расположение преуспевая последний элемент обратной строке.
Заметки
rend используется с обратной строкой как конец используется со строкой.
Если возвращаемое значение rend присвоено const_reverse_iterator, строковые объекты не могут быть изменены.Если возвращаемое значение rend присвоено reverse_iterator, строковый объект может быть изменен.
rend можно использовать для тестирования достиг ли реверсивный итератор закрыть его строки.
Значение, возвращаемое rend не должно быть разыменованно.
Пример
// basic_string_rend.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
string str1 ("Able was I ere I saw Elba"), str2;
basic_string <char>::reverse_iterator str_rIter, str1_rIter, str2_rIter;
basic_string <char>::const_reverse_iterator str1_rcIter;
str1_rIter = str1.rend ( );
str1_rIter--;
cout << "The last character-letter of the reversed string str1 is: "
<< *str1_rIter << endl;
cout << "The full reversed string str1 is:\n ";
for ( str_rIter = str1.rbegin( ); str_rIter != str1.rend( ); str_rIter++ )
cout << *str_rIter;
cout << endl;
// The dereferenced iterator can be used to modify a character
*str1_rIter = 'o';
cout << "The last character-letter of the modified str1 is now: "
<< *str1_rIter << endl;
cout << "The full modified reversed string str1 is now:\n ";
for ( str_rIter = str1.rbegin( ); str_rIter != str1.rend( ); str_rIter++ )
cout << *str_rIter;
cout << endl;
// The following line would be an error because iterator is const
// *str1_rcIter = 'T';
// For an empty string, end is equivalent to begin
if ( str2.rbegin( ) == str2.rend ( ) )
cout << "The string str2 is empty." << endl;
else
cout << "The stringstr2 is not empty." << endl;
}
Требования
заголовок: <string>
std пространство имен: