Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
21 ошибка прогр... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
ТЕХНОЛОГИИ ДОСТ... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Имитационное мо... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Реклама
Сейчас на сайте
Гостей: 10
На сайте нет зарегистрированных пользователей

Пользователей: 13,370
новичок: dogoco6
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Медиа плейер на Delphi + Пояснительная записка
Метод конечных разностей для интерполяции/экстраполяции на Delphi
База данных студентов на Turbo Pascal (Списки) + Пояснительная записка

Реализация простого класса строк
Символьный массивсамый распространенный тип массива в С++. Объясняется это тем, что встроенного строкового типа в С++ нет. Хотя средства обработки строк в С++ достаточно развиты (см. приложение), для изучения механизма использования массивов как полей классов реализуем простой класс строк, похожих на строки Turbo Pascal [44], а заодно разберемся и с перегрузкой операции индексирования operator []. Отметим, что для добавления строк в язык программирования в системе Turbo Pascal потребовалось реализовать их в трансляторе, а мы сделаем это сами средствами стандартного языка С++.
Назовем наш класс строк TString, чтобы не иметь проблем со стандартным классом string, который реализован в составе стандартной библиотеки С++ (см. п. 21 в [1]). В Turbo Pascal строка представляет собой массив байтов длиной 256 элементов. Первый байт содержит длину строки, остальные байты — информационные, они содержат символы строки. Индексы символов изменяются от 1 до 255. В системе реализованы операции сравнения, присваивания, сцепления строк и индексирования отдельного символа. Со строками в системе Turbo Pascal оперируют шесть функций:
? L е n g t h () возвращает длину строки;
? Pos() выполняет поиск одной строки в другой слева направо; результатом является номер первого символа найденной строки или нуль, если строка не найдена;
? Delete() удаляет из строки заданное количество символов, начиная с указанного;
? Insert() выполняет вставку одной строки в другую после указанного символа;
? Сору () возвращает подстроку исходной строки;
? Concat () выполняет сцепление произвольного количества строк.
Кроме того, со строками работают стандартные функции ввода-вывода системы Turbo Pascal.
Очевидно, что набор операций слишком ограничен, поэтому в нашем классе TSt г i ng существенно расширим множество методов и операций, по возможности максимально приблизив интерфейс класса к интерфейсу стандартного класса string.
Обязательный набор операций включает в себя все операции сравнения, а также операции сцепления + и индексирования [ ]. Писать операцию присваивания, очевидно, нет необходимости, так как она создается по умолчанию. Помимо перечисленных, мы можем реализовать еще несколько полезных операций. Первым кандидатом является операция сцепления с присваиванием +=. Операции удаления подстроки тоже можно разнообразить, реализовав, например, операции -= и -.
Перегруженные операции дают возможность оперировать только всей строкой. Для манипулирования подстроками реализуем множество дополнительных методов:
? присваивания с общим именем assign;
? сравнения с общим именем compare;
? поиска подстроки слева и справа с общими именами find и rfind соответственно;
? добавления, удаления, вставки и замены подстрок с общими именами append, erase, insert и replace;
? преобразования строки в верхний и нижний регистры.
Полезной также будет функция substrO, возвращающая подстроку текущей строки. Так как преобразование строки в верхний и нижний регистры представляет собой фактически унарную операцию, преобразование в верхний регистр можно реализовать, перегрузив операцию инкремента ++, а преобразование в нижний регистр — перегрузив операцию декремента
Нам потребуются конструктор без аргументов и несколько конструкторов инициализации: символьной и строковой константой, подстрокой уже объявленной строки и символьного массива. Конструктор копирования, как обычно, можно не определять. Интерфейс класса TString представлен в листинге 4.2.

Листинг 4.2. Интерфейс класса TString
class TString { public:
typedef unsigned char byte: // для сокращения записи
// конструкторы
TStringO:size(),s() { }; // конструктор без аргументов
TString(const char ch, byte count = 1); TString(const char S[]);
TString(const char *First, const char *Last);
TString(const char S[], byte ind, byte count=-l);
TString(const TString &S, byte ind, byte count=-l); // методы присваивания
TString& assign(const char ch, byte count = 1);
TString& assign(const char rhs[], byte ind, byte count=-l);
TString& assign(const char *First, const char *Last);
TString& assign(const TString &rhs, byte ind, byte count=-l); // индексирование
char& operator[](const byte &ind);
const char& operator[](const byte &ind) const;
byte LengthO const { return size; }




Листинг 4.2 (продолжение)
const TString &rhs) const;
byte pos_rhs. byte count_rhs) const; const char rhs[]) const;
II сравнение
int compare(byte pos, byte count int compare(byte pos, byte count
const TString &rhs, int compare(byte pos, byte count int compare(const char *First, const char *Last) const; int compare(byte pos, byte count,
const char rhs[], byte pos_rhs, byte count_rhs) const; // добавление в конец
TString& oper'ator+=(const TString &rhs); TString& append(const char ch, byte count = 1); TString& append(const char rhs[], byte ind, byte count=-l); TString& append(const char *First, const char *Last); TString& append(const TString &S, byte ind, byte count=-l); // вставка в строку
TString& insert(byte pos, TString& insert(byte pos.
byte ind, byte count = -1);
byte n, const char ch, byte count = 1);
byte n, const char rhs[], byte count = -1);
byte n, const char *First, const char *Last);
byte n, const TString &rhs);
byte n,
byte ind, byte count = -1);
const char ch, byte count = 1); const char rhs[], byte count = -1); TString& insert(byte pos, const char *First, const char *Last); TString& insert(byte pos, const TString &rhs); TString& insert(byte pos,
const TString &rhs
// замена подстроки
TString& replace(byte pos, TString& replace(byte pos, TString& replace(byte pos, TString& replace(byte pos, TString& replace(byte pos,
const TString &rhs
// удаление подстроки
TString& erase(byte pos, byte count = -1); TString& operator-=(const TString &rhs); // получение подстроки
TString substr(byte pos, byte count = -1) const; // поиск подстрок // поиск слева направо
byte find(const TString &rhs, byte pos = 0) const; byte find(byte index, const TString &rhs, byte pos = 0) const; byte find(const char rhs[], byte pos = 0) const; byte find(byte index, const char rhs[], byte pos = 0) const; byte find(const char rhs) const; byte find(byte index, const char rhs) const; // поиск справа налево
byte rfind(const TString &rhs, byte pos = 0) const; byte rfind(byte index, const TString &rhs, byte pos = 0) const; byte rfind(const char rhs[], byte pos = 0) const; byte rfind(byte index, const char rhs[], byte pos = 0) const; byte rfind(const char rhs) const; byte rfind(byte index, const char rhs) const; // смена регистра
// toUpper // toLower
TString operator++(); TString operator--(); // дружественные функции
friend TString operator+(const TString &lhs, const TString &rhs); friend TString operator-(const TString &lhs, const TString &rhs);
friend ostream& operator<<(ostream& t, const TString &S); friend istream& operator>>(istream& t, TString &S); friend bool operator==(const TString &lhs, const TString &rhs); friend bool operator!=(const TString &lhs, const TString &rhs); friend bool operator<(const TString &lhs, const TString &rhs); friend bool operator>(const TString &lhs, const TString &rhs); friend bool operator<=(const TString &lhs, const TString &rhs); friend bool operator>=(const TString &lhs, const TString &rhs); private:
byte size; char s[256];
}:



Если у вас свой дом и вам нужен громоотвод, то подробнее об этом можете почитать тут - http://groundtech.ru/interesnye-materialy/153-gromootvod-svoimi-rukami.html.
Поля данных в нашем классе, естественно, закрыты. Поле size содержит длину строки. Строки Turbo Pascal не завершаются нулем и имеют максимальную длину 255 символов, но мы для надежности зарезервировали массив на 256 байт, чтобы в последнем байте всегда был нуль — это гарантирует нам отсутствие неожиданностей при обработке массива функциями библиотеки <cstring>1. Индексирование символов, как принято в С++, будем начинать с нуля. Индекс последнего символа равен 254, а максимальная длина строки — 255 символам.
Опубликовал Kest September 16 2013 21:07:16 · 0 Комментариев · 4034 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
CwstatusBar
index.php + мод ...
IconCut [Исходник...
Report
Разработка Web-пр...
Прграммирование в...
Illusion
Секреты программи...
База Allsubmitter...
Самоучитель PHP 5...
Х. М. Дейтел, П. ...
Платформа програм...
Borland Delphi 6....
Borland C++Builde...
Учебник по создан...
Gold Submitter II...
DeleteEdit
Adapter (пример D...
Crypt32
Пример клиента ФТ...

Топ загрузок
Приложение Клие... 100774
Delphi 7 Enterp... 97836
Converter AMR<-... 20268
GPSS World Stud... 17014
Borland C++Buil... 14191
Borland Delphi ... 10291
Turbo Pascal fo... 7374
Калькулятор [Ис... 5984
Visual Studio 2... 5207
Microsoft SQL S... 3661
Случайные статьи
Введение
Содержание
Компонент изображение
брандмауэре
Скорость в интерне...
Игнорирование отри...
Важность библиотек
OpenGL. МИНИМАЛЬНА...
между этими компью...
Массивы в среде Vi...
Онлайн-казино Фан-...
Что собой представ...
Опции программы «T...
IBS Вы можете пред...
Водородная энергет...
адресу 131
Services for Macin...
Процедур согласова...
File components ma...
Первые шаги. Дейст...
Оптимизация програ...
Юрист по арбитражн...
Сортировка выбором
Сам механизм RTTI ...
Gaminator казино
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?