- •Вычисления значений
- •Пример:
- •Вычисления типов
- •Преимущества мета подхода:
- •Польза использования mpl:
- •Специализация
- •Первичный шаблон:
- •Инстанцирование:
- •Метафункции
- •Числовая метафункция
- •Свойства
- •Метаданные
- •Полиморфизм
- •Возможности свойств:
- •Организация свойств в Boost:
- •Пример:
- •Типовые ассоциации
- •Альтернатива:
- •Метафункции Продвижение (пересылка) метафункций
- •Класс метафункции
- •Формат:
- •Числовые
- •Пример:
- •Нульарные
- •Метрический анализ (Анализ размерностей)
- •Метрики
- •Величины
- •Сложение и вычитание
- •Умножение
- •Класс метафункции
- •Деление
- •Пример:
- •Метафункции высшего порядка (Каскады вложенных вызовов)
- •Использование apply:
- •Заполнители
- •Безымянный заполнитель:
- •Определение выражений с заполнителями
- •Лямбда (Лямбда метафункции/выражения)
- •Частичное приложение метафункции
- •Лямбда и Шаблоны Неметафункции
- •Обертки
- •Выбор типа
- •Ленивый Выбор Типа
- •Логические Операторы
- •Целочисленные обертки
- •Составные Операторы
- •Операторы с булевым значением:
- •Операторы для сравнения значений:
- •Операторы для интегральных значений:
- •Побитовые операторы:
- •Арифметические операторы:
- •Целочисленная «стенография»
- •Интегральные последовательности
- •Формат:
- •Последовательности
- •Концепции
- •Итераторы
- •Двунаправленные
- •Произвольные
- •Последовательности
- •Двунаправленные
- •Произвольные
- •Расширенные
- •Ассоциативные
- •Требования
- •Расширения
- •Расширенные ассоциативные последовательности
- •Алгоритмы и последовательности
- •Итераторы
- •Равенство
- •Операции Внутренние операции с последовательностей
- •Наследование
- •Создание последовательности
- •Реализация:
- •Создание итератора
- •Преимущества полной специализации перед частичной:
- •Добавление расширения
- •Алгоритмы
- •Абстракция:
- •Stl алгоритмы
- •Детали правильного использования stl:
- •Mpl алгоритмы
- •Различия stl и mpl алгоритмов:
- •Пример:
- •Вставки
- •Пример 1:
- •Пример 2:
- •Пример 3:
- •Фундамент алгоритмов
- •Пример:
- •Запрашиваемые алгоритмы
- •Последовательности (Алгоритмы, создающие последовательности)
- •Синонимы функциональных алгоритмов:
- •Создание алгоритма
- •Итераторы «Просмотр» и итераторы-адаптеры
- •Концепция просмотра
- •Применение просмотра Сравнения значений элементов последовательности:
- •Упрощение 1
- •Упрощение 2 (создание просмотра)
- •Объединение множественных (мульти-) последовательностей
- •Уход от ненужного вычисления
- •Выборочная обработка элемента
- •Итератор-адаптер
- •Создание просмотра
- •Реализация итератора-адаптера для zip_view.
- •Диагностика
- •Отладка ошибок
- •Трассировка инстанцирования
- •Исправленный пример:
- •Форматы сообщений об ошибках
- •Блок «with»
- •Устранение параметров шаблона по умолчанию
- •Глубокий typedef
- •Инструменты
- •Несколько компиляторов
- •(Статические Утверждения)
- •Формат:
- •Формат:
- •Индивидуальные сообщения утверждений
- •Настройка предиката:
- •(Генерирование встроенных сообщений)
- •Формат:
- •Выбор стратегии:
- •Тип печати
- •Кросс этапность компиляции/выполнения
- •Печать типов:
- •Тип посещения:
- •Выбор реализаций
- •Специализация шаблонов классов
- •Тег диспетчеризации
- •Выбор структуры
- •Композиция классов
- •Указатели на функцию
- •Ослабление типизации
- •Пример:
- •Обобщение:
- •Динамический полиморфизм
- •Автоматизация
- •Сохранение интерфейса
- •Рекуррентный шаблон
- •Формат:
- •Генерирование функций
- •Управление разрешением перегрузки
- •Явное управление множеством перегрузки
- •Документация mpl Последовательности
- •Концепции
- •(Прямая последовательность)
- •(Двунаправленная Последовательность)
- •(Последовательность произвольного доступа)
- •(Расширенная последовательность)
- •(Расширенная последовательность начала)
- •(Расширенная последовательность конца)
- •(Ассоциативная последовательность)
- •(Расширенная ассоциативная последовательность)
- •(Обертка интегральной последовательности )
- •(Переменная последовательность)
- •Представления
- •Метафункции (Внутренние)
- •Итераторы
- •Концепции
- •(Прямой итератор)
- •(Двунаправленный итератор)
- •(Итератор произвольного доступа)
- •Метафункции
- •Алгоритмы
- •Концепции
- •(Инсертер: механизм вставок)
- •Инсертеры (инсертер: механизм вставок)
- •Итеративные алгоритмы
- •Запрашиваемые алгоритмы
- •Преобразования
- •Метафункции
- •Концепции Метафункция
- •Метафункциональный класс
- •Лямбда выражения
- •Заполнители
- •Тэг диспетчеризированные метафункции
- •Числовые метафункции
- •Тривиальные метафункции
Специализация
Работа со специализациями сопряжена с двумя основными моментами:
Обращение к шаблонному классу передавая ему в качестве аргумента конкретный тип:
Явная (полная) и частичная специализации; Синтаксис явной специализации:
template <variable part>
struct template-name<fixed part>
В явной (или полный) специализация, variable part -остается пустой, а fixed part заполняется конкретными аргуменатми шаблона, тип которых соответсвует в списке параметров.
В частичной специализации variable part содержит список параметров, и по крайней мере один параметр в fixed part зависит от параметров из variable part.
Первичный шаблон:
Объявление шаблона, который не является специализацией - основной шаблон. Основной шаблон можно расматривать как вариант по умолчанию, для работы с общими случаями, в то время как специализации обрабатывают особые ситуации.
Инстанцирование:
Фактическое заполнение шаблонных параметров конкретными типами, с генерированием отдельной версии данного шаблона (обычно располагается в конце единицы трансляции), на этом этапе происходит выбор оснонвой или специализированной версии шаблона, осуществляется дополнительная проверка на ошибки. Нюанс: тела функций- шаблонных классов не проверяются до момента инстанцирования – фактического использования:
template <class T, class U>
struct X
{
int f(T* x) // declaration
{
U y[10]; // definition
return 0;
}
};
typedef X<int&, char> t1; // OK; no instantiation yet
t1 x1; // error: int&* - illegal
typedef X<int, char&> t2; // OK; declarations check out
t2 x2; // ОК, но ошибка в теле функции шаблонного класса не обнаружена
int a = x2.f(); // error: array of char& illegal
Т.о., от шаблонное инстанцирование влияет как на скорость компиляции, так и на то, что компиляция вообще будет выполнена.
Метафункции
«Функция», которая работает с метаданными и может быть «вызвана» во время компиляции:
some_metafunction<Arg1, Arg2>::type
Аналогичный вызов на этапе выполнения:
some_function(arg1, arg2)
Числовая метафункция
Метафункция, которая возвращает тип обертки для численного значения. Большинство числовых метафункций содеражт вложенный элемент «::value»:
some_numerical_metafunction<Arg>::value
Вместо более общего
some_numerical_metafunction<Arg>::type::value
Для доступа к числовому результату непосредственно.
Свойства
(Traits)
Метаданные
Все «значения/типы», с которыми ведется работа на этапе компиляции. Два наиболее распространенных вида: типы и целочисленные константы (включая bool). Часть времени компиляции C++ часто упоминается как «чистый функциональный язык», потому что метаданные являются неизменными, и у метафункций не может быть никаких побочных эффектов.
Блоб
Класс с большим количеством элементов (включая функции класса). Элементы такого класса все «связаны» с друг другом, потому что они объявляются вместе. Это ограничивает приницпы полиморфизма, сужает модульность, потому такой модели лучше избегать, альтернатива: boost::свойства и метафункции.
