Навигация
Главная
Поиск
Форум
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
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Модуль Forms 65535
ТЕХНОЛОГИИ ДОСТ... 63087
Имитационное мо... 58363
Реклама
Сейчас на сайте
Гостей: 8
На сайте нет зарегистрированных пользователей

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

Выбор наилучших альтернатив с использованием методов оптимизации на Delp...
Принадлежит ли точка пересечению двух окружностей на Turbo Pascal + Отче...
Сравнение двух бинарных деревьев на Turbo Pascal + отчет

Реклама



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

ПОДПИСЫВАЙСЯ на канал о программировании
Параметр-шаблон
Еще один вариант реализации использовать в качестве параметра шаблон (см. п. п. 14.3.3 в [1]). Это дает нам возможность иметь разные реализации очередей в зависимости от контейнера, который передается классу-шаблону TQueue в качестве аргумента. Параметру-шаблону, как и любому другому виду параметров шаблонного класса, можно присвоить значение по умолчанию — пусть это будет наш класс TSimpleArray. Посмотрите, как это делается (листинг 11.8).

Листинг 11.8. Шаблонный параметр шаблона
template <typename Т, // тип элементов
std::size_t N = 1000, // количество
template <class, std::size_t> // параметр-шаблон
class Container = TSimpleArray // значение по умолчанию
> // конец списка
class TQueue
{ Container<T, N> t; // поле-контейнер
public: // методы
};
Параметр-шаблон объявлен последним:
template <class, std::size_t> class Container = TSimpleArray



1 Не запутались? Можно сказать по-другому: имена параметров параметра-шаблона.
Так же как обычный шаблон, параметр начинается с ключевого слова template, за которым следует список его параметров. Однако в списке параметров параметра-шаблона не задаются имена параметров1 — они просто не используются.
Можно провести аналогию с неиспользуемым параметром при реализации постфиксной операции инкремента operation++(int).
Объявление такого контейнера в программе может выглядеть так:
TQueue<double> ql; // размер и контейнер по умолчанию
TQueue<double, 5000> q2; // контейнер по умолчанию
TQueue<double, 500, TSimpleArray> q3; // все задано явно



Обратите внимание, что в третьем варианте задается только имя контейнера без аргументов. Вместо нашего массива подойдет любой контейнер, имеющий два аналогичных параметра: тип элементов и беззнаковое целое. Вспомним «умный» массив ТАггау (см. листинг 6.10) и преобразуем его в шаблон. Интерфейс нового шаблонного класса практически не отличается от интерфейса TSimpleArray (листинг 11.9).

Листинг 11.9. Шаблонный класс
ТАггау
template <typename Т = double, std::size_t n = 100>
class TArray
{ public:
// определение типов
typedef std::size_t size_type;
typedef std::size_t index_type;
typedef T value_type;
typedef T& reference;
typedef T* iterator;
typedef T* pointer;
TArray(size_type size, value_type k=0.0);
TArray(const TArray &a);
TArray(const TArray &a, index_type begin, size_type k); TArray(const iterator begin, const iterator end); ~TArray();
reference operator[](index_type index);
const reference operator[](index_type index) const;
TArray& operator=(const TArray &a);
TArray& assign(const TArray &a, index_type I, index_type r); TArray& assign(const iterator begin, const iterator end); size_type sizeQconst { return size_array; }; iterator find(const value_type &a); friend ostream& operator <<(ostream& to, const TArray &a); friend istream& operator >>(istream& to, TArray &a); private:
size_type size_array; pointer data;
};



Обратите внимание, как мало нам пришлось изменить для преобразования класса ТАггау в шаблон: фактически добавился только заголовок шаблона и в определении типов слово double заменено параметром шаблона Т. При правильном подходе возможные изменения инкапсулируются в небольшой области текста и минимизируются.
Параметры шаблона сделаны точно такими, как в шаблоне TSimpleArray. Поэтому этот класс можно использовать в качестве аргумента при объявлении объекта-очереди:
TQueue<double, 500, TArray> Q4; // все задано явно



Отметим некоторые особенности объявления параметра-шаблона. Во-первых, количество, порядок и типы параметров параметра-шаблона должны в точности соответствовать параметрам подставляемого аргумента-шаблона (в данном случае — TSimpleArray). Нельзя, например, переставить их местами:
template <std::size_t, class> class Container = TSimpleArray



Точно такие же параметры имеет и второй шаблонный класс — ТАггау.
Во-вторых, в списке параметров параметра-шаблона разрешается вместо слова class использовать слово typename, например:
template <typename, std::size_t> class Container = TSimpleArray



Однако перед именем самого параметра-шаблона можно писать только слово class:
class Contaner



Не разрешается писать ни слово typename, ни слово struct, ни слово union.
В-третьих, некоторые проблемы доставляют параметры по умолчанию. Наш контейнер TSimpleArray такой параметр имеет — это количество элементов массива N. В шаблоне TQueue задан собственный параметр N и ему присвоено значение по умолчанию 1000. Однако очередь, вообще говоря, — структура данных потенциально бесконечная, поэтому количество элементов внутреннего контейнера должно быть его «внутренним» делом; предполагается, что контейнер самостоятельно управляется со своей памятью. Но задавать значения по умолчанию в шаблоне-параметре нельзя — его имена компилятором не рассматриваются в качестве аргументов! Например:
template <typename Т,
template <class, std::size__t N = 100> class Container=TSimpleArray
>



Этот заголовок шаблона TQueue в Visual C++.NET 2003 при объявлении поля-контейнера Container <Т, N> t; вызывает ошибку компиляции о неопределенном имени N:
error С2065: 'N' : undeclared identifier



Поэтому нам пришлось вынести этот параметр на верхний уровень.
Опубликовал Kest December 16 2013 01:33:06 · 0 Комментариев · 2339 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
CoolControls v3.0...
Секреты программи...
Пользовательская...
PHP: обучение на ...
Domen Name IP
Профессиональное ...
DFileDeleter
Просмотр файлов и...
SendSMS для PHP-F...
Java 2. Наиболее ...
AVIwriter
Мониторинг сервер...
FormShape [Исходн...
Пример создания W...
Delphix Sample [И...
Ведение справочны...
PBEditPack
Задача о 8ми ладьях
Библия хакера 2. ...
Эффект лампы на р...

Топ загрузок
Приложение Клие... 100481
Delphi 7 Enterp... 87905
Converter AMR<-... 20082
GPSS World Stud... 13574
Borland C++Buil... 12072
Borland Delphi ... 8676
Turbo Pascal fo... 7048
Visual Studio 2... 5005
Калькулятор [Ис... 4912
FreeSMS v1.3.1 3545
Случайные статьи
ИСПОЛЬЗОВАНИЕ ПРЕД...
Символы, используе...
Опыты с силой прит...
Назначение онлайно...
Автоматическая игр...
Безызбыточное коди...
Листинг 13.22. Фун...
Программирование: ...
12.4. Принципы
ПРИЛОЖЕНИЕ 5. Карт...
Создание интернет ...
Параметры восстано...
Получая пакеты, бр...
кроме субботы с 18...
Конструктор копии
Приемы синтезаторов.
Списки в Прологе
Как защитить сайт ...
contoso
Протокол IP-адрес ...
Как увидеть пробле...
Fall only allowed ...
Адресное пространство
ВОЗДЕЙСТВИЕ ОТСЕЧЕ...
Установка WordPress
Статистика



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


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