basic_string::end
Retorna um iterador que trata o local após o último elemento na cadeia de caracteres.
const_iterator end( ) const;
iterator end( );
Valor de retorno
Retorna um iterador de acesso aleatório que a fim de atender ao local que tem êxito o elemento o mais recente em uma cadeia de caracteres.
Comentários
end é frequentemente usado para testar se um iterador um chegou ao final da cadeia de caracteres. O valor retornado por end não deve ser cancelado.
Se o valor de retorno de end é atribuído a const_iterator, o objeto de cadeia de caracteres não pode ser alterado. Se o valor de retorno de end é atribuído a iterator, o objeto de cadeia de caracteres pode ser alterado.
Exemplo
// basic_string_end.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
string str1 ( "No way out." ), str2;
basic_string <char>::iterator str_Iter, str1_Iter, str2_Iter;
basic_string <char>::const_iterator str1_cIter;
str1_Iter = str1.end ( );
str1_Iter--;
str1_Iter--;
cout << "The last character-letter of the string str1 is: " << *str1_Iter << endl;
cout << "The full orginal string str1 is: " << str1 << endl;
// end used to test when an iterator has reached the end of its string
cout << "The string is now: ";
for ( str_Iter = str1.begin( ); str_Iter != str1.end( ); str_Iter++ )
cout << *str_Iter;
cout << endl;
// The dereferenced iterator can be used to modify a character
*str1_Iter = 'T';
cout << "The last character-letter of the modified str1 is now: "
<< *str1_Iter << endl;
cout << "The modified string str1 is now: " << str1 << endl;
// The following line would be an error because iterator is const
// *str1_cIter = 'T';
// For an empty string, end is equivalent to begin
if ( str2.begin( ) == str2.end ( ) )
cout << "The string str2 is empty." << endl;
else
cout << "The stringstr2 is not empty." << endl;
}
Requisitos
Cabeçalho: <cadeia de caracteres>
Namespace: std