Поэкспериментируем с этим классом-шаблоном и его статическим методом printO (листинг 13.17).
Листинг 13.17. Статические элементы шаблона — модель включения
#include "StaticField.h" // модель включения
#include <iostream> using namespace std;
Static<long> r; // глобальный объект
int main()
{ // объектов типа Static<double> не существует
Static<double>::print(); cout << endl; // значение по умолчанию
Static<double>::print(234); cout << endl; // изменили значение поля t
Static<double> r; // локальный объект создан
Static<double>::print(); cout << endl; // значение поля t = 234.0
// один объект типа Static<long> уже существует!
Static<long>::print(); cout << endl; // значение 0
Static<long>::print(4321); cout << endl; // изменили значение поля t
r.print(); cout << endl; // локальный объект
:: r.printO; cout << endl; // глобальный объект
Static<int> t;
Static<int>::print(); cout << endl; Static<int>::print(100); cout << endl; return 0;
}
Сначала объявляется глобальный объект г. Соответственно создаются статические элементы класса Static<long>:
• статическое поле count, не зависящее от аргумента шаблона;
• статическое поле static long t, проинициализированное нулем;
• статический метод void print(long).
Упражнения
3. Написать шаблон функции реверсирования последовательности элементов, задаваемых двумя итераторами. Использовать шаблон стека (см. листинг 11.1).
4. Написать шаблон функции пузырьковой сортировки, параметрами которой являются два итератора. Отсортировать с ее помощью массив целых чисел типа int и массив дробных чисел типа double.
5. Добавить к параметрам функции сортировки из предыдущего упражнения третий параметр — функцию для сравнения элементов, на которые указывают итераторы. Функция сортировки должна вызывать функцию сравнения для сравнения элементов, на которые указывают итераторы. Функция сравнения возвращает значение типа bool.
6. Выполнить предыдущее упражнение, создав класс-оболочку (см. листинг 12.8) для функции сравнения и реализовав ее в классе как операцию operators
7. Разработать обобщенный алгоритм count_if () для вычисления количества элементов контейнера, удовлетворяющих заданному условию, по образцу алгоритма copy__i f () (см. листинг 12.7). Параметрами должны являться итераторы и функторы. Для демонстрации работы алгоритма использовать шаблоны динамических массивов и шаблоны списков. Реализовать два разных функтора.
8. Написать шаблоны функторов для всех операций сравнения по образцу шаблона функтора Greater.
9. Реализовать алгоритм binoperateO, выполняющий заданную функтором операцию с двумя интервалами и записывающий результат в выходную последовательность.
10. Использовать шаблоны функтора Greatero и less<> из упражнения 8 для сортировки элементов последовательности в функции сортировки из упражнения 5.
11. Реализовать адаптер указателя на метод для операции - >*. |