Анимация
JavaScript


Главная  Библионтека 

0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 [ 148 ] 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239

Попробуем запустить эту «полезную и нужную* программу для следующих входных данных;

pots & pans I saw a reed

Результат выглядит так:

stop & snap I was a deer

Описание строковых классов Строковые типы

Все строковые типы и функции определяются в заголовочном файле <string>;

#1nclude <str1ng>

Как обычно, все идентификаторы принадлежат пространству имен std.

Шаблонный класс basic string

в файле <string> определяется базовый шаблон для всех строковых типов basic string:

namespace std (

tempiate<class charT.

class traits = char tra1ts<charT>.

class Allocator = allocator<charT> > class bas1c str1ng;

Шаблон параметризуется по типу символов, трактовкам символьного типа и модели памяти.

О Первый параметр определяет тип данных отдельного символа.

О Необязательный второй параметр определяет класс трактовок, описывающих основные операции с символами строкового класса. В частности, класс трактовок задает способ копирования и сравнения символов (за подробностями обращайтесь на с. 659). Если класс трактовок не указан, используется класс трактовок по умолчанию для указанного типа символов. Пример пользовательского класса трактовок, позволяющего обрабатывать строки без учета регистра символов, приведен на с. 485.

О Третий необязательный аргумент определяет модель распределения памяти, используемую строковым классом. Как обычно, по умолчанию задействуется модель ailocator (за подробностями обращайтесь на с. 49 и к главе 15)*.

В системах, не поддерживающих параметры шаблонов по умолчанию, третий аргумент обычно отсутствует.



Конструкторы

Создание и копирование cipOK

Деструктор

Уничтожение строк

assignQ

Присваивание нового значения

swapO

Обмен содержимым двух строк

+=, appendO, push back()

Присоединение символов

insert()

Вставка символов

eraseO

Удаление символов

clear()

Удаление всех символов (строка остается пустой)

resizeO

Изменение количества символов (удаление и присоединение

символов в конце)

replaceO

Замена символов

Конкатенация строк

i=/ </ >/ >=, compareO

Сравнение строк

Типы string и wstring

Стандартная библиотека С++ содержит две специализированные версии класса basic string<>.

О string - специализированная версия шаблона для символов типа char:

namespace std {

typedef bas1c string<char> string:

О wstring - специа1изированная версия шаблона для символов типа wchar t:

namespace std {

typedef bas1c str1ng<wchar t> wstring;

Эта версия позволяет работать со строками, содержащими символы в многобайтовой кодировке (например, в кодировке Unicode или в азиатских кодировках - проблемы интернационализации рассматриваются в главе 14).

В данной главе эти два типа строк не различаются. Принципы использования и возникающие проблемы остаются одинаковыми, поскольку все строковые классы обладают одинаковым интерфейсом. Таким образом, «строка» в данном контексте означает любой строковый тип, включая string и wstring. В приводимых примерах обычно используется тип string, потому что программы, как правило, пишутся в расчете на европейскую и англо-американскую языковую среду.

)перации со строками

в табл. 11.1 перечислены все операции, определенные для строк.

Таблица 11.1. Операции со строками Операция Описание



Глава 11. Строки

Таблица 11.1 (продолжение)

Операция

Описание

SizeO, lengthO

Получение количества символов

max size()

Получение максимально возможного количества символов

emptyO

Проверка пустой строки

capacityO

Получение количества символов, которые могут храниться

в памяти без перераспределения

reserveO

Резервирование памяти для заданного количества символов

[LatO

Обращение к символу

>>, getlineO

Чтение строковых данных из потока данных

<<

Запись строковых данных в поток данных

copyO

Копирование или запись содержимого строки в С-строку

c str()

Получение содержимого строки в виде С-строки

dataO

Получение содержимого строки в виде символьного массива

substrO

Получение подстроки

Поисковые функции

Поиск заданных подстрок и символов

beginO, end()

Поддержка «нормальных» итераторов

rbeginO, rend()

Поддержка обратных итераторов

get ailocatorO

Получение распределителя памяти

Аргументы операций со строками

Стандартная библиотека нодлерживает множество операций, предназначенных

для работы со строками. В частности, операции, изменяющие содержимое стро-

ки, обычно существуют в

нескольких перегруженных версиях, в которых но-

вое значение задается одним, двумя или тремя аргументами. Во всех опера-

циях такого рода используется схема передачи аргументов, представленная

в табл. 11.2.

Таблица 11.2. Схема передачи аргументов строковых операций

Операция

Описаиие

const 5tring& str

Вся Сфока str

const sLring& str, size type idx,

Не более первых num символов str, начиная

size type num

с индекса idx

const char* str

Вся С-сгрока

const char* chars, size type len

Первые len символов символьного массива chars

char с

Символ с

size type num, char с

Num экземпляров символа с

iterator beg, iterator end

Все символы в интервале [beg,end)



0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 [ 148 ] 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239