Навигация
Главная
Поиск
Форум
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
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Содержание сайт... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Создание отчето... 65463
Модуль Forms 65221
Пример работы с... 64764
ТЕХНОЛОГИИ ДОСТ... 61922
Имитационное мо... 57796
Реклама
Сейчас на сайте
Гостей: 10
На сайте нет зарегистрированных пользователей

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

Моделирование работы ЭВМ на GPSS + Пояснительная записка
Обработка задач на ЭВМ на GPSS + Пояснительная записка
Поиск пути в графе заданном списками инцедентности на Turbo Pascal

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Другие операции
И наконец, займемся реализацией операций со строками. В первую очередь, рассмотрим операции сцепления, и начнем с операции сцепления с присваиванием (листинг 4.10).

Листинг 4.10. Реализация операции сцепления с присваиванием
TString& TString::operator+=(const TString &rhs)
{ memcpy(s+size, rhs.s, 255-size): // дописываем строку
size = strlen(s); // новая длина
return *this:
}



С помощью функции memcpy () (см. приложение) мы просто «дописываем» в «хвост» текущей строки начало строки-аргумента, причем ровно столько символов, сколько имеется «свободных» нулевых байтов в текущей строке. В число переписываемых попадают и нулевые байты прицепляемой строки. Затем устанавливается новая длина текущей строки и выполняется возврат ссылки на текущий объект, чтобы операцию, как и стандартную, можно было применять многократно.
Нам достаточно иметь реализацию только с аргументом типа TString, так как преобразование параметра обеспечивают конструкторы инициализации.
С помощью этой операции и конструкторов мы легко реализуем другие операции сцепления, что можно наблюдать в листинге 4.11. Все методы append (), как и методы assi gn (), реализованы однотипно: с помощью подходящего конструктора создается локальный объект-строка, которая прицепляется к текущей строке.

Листинг 4.11. Реализация методов сцепления
TString& TString::append(const char ch, byte count)
{ TString t(ch, count): // локальная строка - проверка параметров
*this+=t; // прицепили к текущей строке
return *this;
}
TString& TString::append(const TString &S, byte ind, byte count) { TString t(S, ind, count); *this+=t; return *this; } // дружественная функция
TString operator+(const TString &lhs, const TString &rhs) { TString t = Ihs; t+=rhs; return t; }



1 Забудьте! Будем считать, что я этого не говорил. Проверять написанный код надо всегда.
Операция сцепления двух строк объявлена и реализована как дружественная, чтобы не иметь проблем с типом левого аргумента. И опять обратите внимание на то, как мы здорово упростили себе работу, использовав конструкторы и уже. реализованную операцию сцепления с присваиванием. Такие функции даже проверять не надо1 — они сразу работают. Если вам понадобился миксер то выбрать его можно тут - миксер цена.
Покажем теперь примеры реализации функций вставки, замены и удаления. Начнем с функции удаления. Метод должен обеспечивать разные варианты удаления символов: в начале, в середине и в конце строки. Последний вариант удаления удобно задавать с одним параметром-индексом, показывающим, начиная с какого символа нужно выполнять удаление. Поэтому количество можно задать по умолчанию равным -1, как в других методах. Текст метода приведен в листинге 4.12.

Листинг 4.12. Метод удаления подстроки
TString& TString::erase(byte pos, byte count)
{ TString tl(*this, 0, pos): // начало строки
if (count != static_cast<byte>(-l)) // преобразование необходимо
{ TString t2(*this, pos+count); // хвост строки
tl+=t2: // получили результат
}
¦this = tl; // присвоили текущему
return *this;
}


Опубликовал Kest September 19 2013 19:35:05 · 0 Комментариев · 2412 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
Панель случайной ...
Разработка клиент...
Доступа к БД Fire...
Работа с картотеками
Программирование ...
iComm v.6.1 - выв...
Игра змейка
PDJ Scrollers
Анекдоты с ostrie.ru
Разработка распре...
Фильтры изображений
Srinilist
Cтатьи Королевств...
Пишем программы и...
Exe in exe
Последнее загруж...
Определние размер...
TelBook
C++ Builder: Книг...
Основы Delphi

Топ загрузок
Приложение Клие... 100470
Delphi 7 Enterp... 87109
Converter AMR<-... 20078
GPSS World Stud... 12864
Borland C++Buil... 11849
Borland Delphi ... 8607
Turbo Pascal fo... 7039
Visual Studio 2... 4999
Калькулятор [Ис... 4806
FreeSMS v1.3.1 3542
Случайные статьи
8.6. Принципы
ДЫРЫ В ЧАТАХ
Рекурсивное постро...
Создание собственн...
ОСНОВНЫЕ ВЫВОДЫ ПО...
Стандартный маршал...
Краткое введение в...
true
Глоссарий продолжение
Canon 1210 картридж
Постоянно продолжа...
СТАНДАРТНЫЕ ЧИСЛОВ...
Надписи
clause(X, Y)
МОДЕЛИРОВАНИЕ МНОГ...
Поток без синхрони...
Использование Outl...
Ассоциативные массивы
Нужно ли продвигат...
Значение каждого б...
,':туп ко ?сем Wt ...
Результаты
Создание структуры...
Инструменты Visual...
Простой дизайн
Статистика



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


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