Навигация
Главная
Поиск
Форум
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
Реклама
Сейчас на сайте
Гостей: 6
На сайте нет зарегистрированных пользователей

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

Моделирование работы обрабатывающего участка цеха в GPSS
Меры близости на векторах в Delphi + Блок схемы
Игра Sokoban на Delphi + Блок схемы

Статические поля-массивы
Наши функции перевода регистра должны обеспечивать перевод и русских, и английских букв. Простейшая реализация методов преобразования в верхний и нижний регистры может быть такой, как в листинге 4.19. Поскольку перевод регистра — разовое действие, то пусть обе операции возвращают значение.

Листинг 4.19. Простейшая реализация методов изменения регистра строки
TString TString::operator++() // toUpper { const char lower[59]
= "abcdefghi ]к1тпоряг51иуихугабвгдежзийклмнопрстуфхцчшщъыьэюя,>;




Подробности см. в главе 14.
const char upper[59]
= ,,ABCDEFGHIJKLMN0PQRSTUVWXYZAБBГДEЖЗИЙKПMH0ПPCTУФXЦЧШЩЪЫbЭЮЯ,,; for(int i = 0; i<this->Length(); i++)
{ for (int j = 0; J < 59; j++) if (s[i] == lower[j]) s[i}=upper[j]; } return *this;
}
TString TString:roperator--() // toLower { const char lower[59]
= "abcdefghi j^тпорд^иуыхугабвгдежзийклмнопрстуфхцчшщъыьэюя"; const char upper[59]
= "АВСОЕРСНиКЬММОРОКБТиУУ^ХУГАБВГДЕЖЗИЙКПМНОПРСТУФХЦЧШЩЬЫЬЭЮЯ"; for(int i = 0; i<this->Length(); i++)
{ for (int j = 0; j < 59; j++) if (s[i] == upperfj]) s[iSlower[j]; } return *this;
}



Методы прекрасно работают, однако в таком виде они нас, конечно, не устраивают — любой программист тут же скажет, что использование локальных массивов очень неэффективно. Массивы заново создаются при каждом входе в функцию — на это тратится и время и место при выполнении программы.
Первое побуждение — вынести массивы из методов и объявить два поля-массива. Но тут нас ожидают некоторые сложности. Во-первых, поля нельзя объявить константными, хотя по сути своей они таковыми и являются. Дело в том, что тогда мы не сможем эти поля инициализировать — константные массивы встроенного типа никаким образом не инициализируются (см. ранее). Но если массивы не константные, то их придется заполнять в каждом конструкторе, написав для этого приватную функцию.
Во-вторых, и это гораздо важнее, неконстантные поля-массивы существенно увеличивают размер класса — на 118 байт. Пока объектов немного, это не доставляет беспокойства. Но представьте, что нам надо объявить массив размером в 1000 элементов типа TStr i ng. Ситуация отнюдь не надуманная, так как подобный массив, например, в качестве буфера может использовать простой текстовый редактор. Но такой массив имеет уже 118 ООО лишних байтов, которые еще и заполняются во время создания — ведь конструктор вызывается для каждого элемента массива. Ситуация совершенно неприемлемая как с точки зрения расхода памяти, так и с точки зрения эффективного выполнения программы.
Программистам просто необходимы качественные и не дорогие дисплеи, которые можно купить в интернет магазине http://vseplus.com/product?cid=35.
Так как массивы у нас символьные, то можно было бы обойтись указателями на символ — тем более, что их можно инициализировать символьной константой. Ситуация с памятью несколько улучшается: два указателя занимают в классе всего 8 байт. Однако указатели тоже будут инициализироваться для каждого создаваемого объекта.
Опубликовал Kest September 25 2013 19:00:21 · 0 Комментариев · 3588 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
Популярные загрузки
Web Регистрация
Delphi 2005. Разр...
Java Server Pages...
CLR via C#
Разработка распре...
NotePad Pro [Исхо...
Х. М. Дейтел, П. ...
Prolog Interprete...
Encrypt Decrypt
Иллюстрированный ...
Панель "ссылки"
Java в примерах -...
Программа для рис...
Программирование ...
Библия хакера 2. ...
Srinilist
Мод "проверочный ...
ComboBox97
Черный круг двига...

Топ загрузок
Приложение Клие... 100814
Delphi 7 Enterp... 98119
Converter AMR<-... 20317
GPSS World Stud... 17100
Borland C++Buil... 14274
Borland Delphi ... 10401
Turbo Pascal fo... 7407
Калькулятор [Ис... 6109
Visual Studio 2... 5248
Microsoft SQL S... 3683
Случайные статьи
Глава 14. Разде...
2.4. ДОПУСТИМЫЕ СП...
Отношения между уч...
1.3.3. Инструменты...
Глоссарий продолжение
Искусственный Инте...
Анализ издержек
Категории итераторов
Устройства тестиро...
Взаимодействие ком...
Кумулятивные суммы
Язык С: определени...
Сложность рекурсив...
Вирусный трафик
Советы дизайнеру, ...
Документ FacebookWork
Основы ведения инф...
Текстуру можно исп...
Способы и схемы по...
Полная пропускная ...
Средства отладки -...
Динамические маршр...
Сканирование фотог...
Определение элементов
Информеры, зачем о...
Статистика



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


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