►Контейнер string...317
Наиболее распространённым типом массива, по-видимому, является нуль-завершённая строка, используемая для вывода текста. В ней наиболее ярко проявляются как достоинства, так и недостатки массивов. Взгляните, насколько просто выглядит следующее выражение:
cout << "Это обычная строка" ;
_________________
317 стр. Глава 28. Стандартная библиотека шаблонов
А вот как выглядит конкатенация двух строк:
char* concatString( char* s1 , char* s2 )
{
int length = strlen( s1 ) + strlen( s2 ) + 1 ;
char* s = new char[ length ] ;
strcpy( s , s1 ) ;
strcat( s , s2 ) ;
return s ;
}
Для работы со строками STL предоставляет контейнер string. Этот класс предоставляет программисту массу операций ( включая перегруженные операторы ), которые упрощают работу со строками символов. Та же конкатенация строк с использованием класса string выглядит гораздо проще:
string concat( string s1 , string s2 )
{
return s1 + s2 ;
}
«До сих пор в программах я старался избегать использования класса string, поскольку вы ещё с ним не знакомы. Однако большинство программистов используют этот класс гораздо чаще, чем массивы символов с завершающим нулевым элементом.»
[Помни!]
Приведённая далее программа демонстрирует несколько возможностей класса string.
/* STLString — демонстрация простейших */
/* возможностей класса string из STL */
#include <string>
#include <cstdlib>
#include <iostream>
using namespace std ;
/* concat — конкатенация двух строк */
string concat( string s1 , string s2 )
{
return s1 + s2 ;
}
/* removeSpaces — удаление всех пробелов из строки */
string removeSpaces( string s )
{
/* Находим смещение первого пробела; продолжаем поиск до тех пор, пока не сможем найти больше ни одного пробела */
size_t offset ;
while ( ( offset = s.find( " " ) ) != -1 )
{
/* Удаляем найденный пробел */
s.erase( offset , 1 ) ;
}
return s ;
}
/* insertPhrase — вставка фразы в том месте, где находится метка <ip> */
string insertPhrase( string source )
{
_________________
318 стр. Часть 5. Полезные особенности
size_t offset = source.find( "<ip>" ) ;
if ( offset != -1 )
{
source.erase( offset , 4 ) ;
source.insert( offset , "Randall" ) ;
}
return source ;
}
int main( int argc , char* pArgs[ ] )
{
setlocale ( LC_ALL , ".1251" ) ; /* печать кириллицы */
/* Создаём строку, которая представляет собой конкатенацию двух меньших строк */
cout << "string1 + string2 = "
<< concat( "string1 " , "string2" )
<< endl ;
/* Создаём тестовую строку и удаляем в ней все пробелы */
string s2( "The phrase" ) ;
cout << "<" << s2 << "> минус пробелы = <"
<< removeSpaces( s2 ) << ">" << endl ;
/* Вставляем фразу в средину существующей строки */
string s3 = "Stephen <ip> Davis" ;
cout << s3 + " -> " + insertPhrase( s3 ) << endl ;
/* Пауза для того, чтобы посмотреть на результат работы программы */
system( "PAUSE" ) ; return 0 ;
}
Оператор operator+( ) выполняет конкатенацию строк, которая раньше осуществлялась при помощи функции concatCharacterString( ).
Функция removeSpaces( ) удаляет все найденные пробелы из строки при помощи операции string::find( ), которая возвращает смещение первого найденного пробела. После того, как положение пробела в строке определено, функция-член erase( ) удаляет его из строки. Метод find( ) возвращает смещение найденного пробела от начала строки, или -1, если он не найден.
«Тип size_t определён в заголовочных файлах STL как целое число, которое в состоянии работать с массивом максимально допустимого на вашем компьютере размера. Обычно это тип long. Использование типа size_t связано с вопросами переносимости исходного кода между различными программно-аппаратными платформами. Visual С++ .NET сгенерирует предупреждение, если вместо size_t вы используете int.»
[Советы]
Функция insertPhrase( ) использует метод find( ) для поиска точки вставки в строку, после чего метод erase( ) удаляет метку вставки <ip> из строки, а метод insert( ) вставляет новую строку в средину старой.
Вот как выглядит вывод данной программы:
string1 + string2 = string1 string2
<The phrase> минус пробелы = <Thephrase>
Stephen <ip> Davis -> Stephen Randall Davis
Press any key to continue...
_________________
319 стр. Глава 28. Стандартная библиотека шаблонов
Больше книг — больше знаний!
Заберите 20% скидку на все книги Литрес с нашим промокодом
ПОЛУЧИТЬ СКИДКУ