Листинг 13.18. Модуль с функцией
#include "StaticField.h" #include <iostream> using namespace std; Static<int> t; void f (void)
Листинг 13.18 (продолжение)
cout << "Inside f()-t ";
{ cout << "Inside f()-t "; t.printO; cout << endl; int у = 123;
t-VSUl 1119 IUC I W ~ L t
Static<int>::print(y); cout << endl;
Объявляется глобальный объект типа Static<int>H демонстрируются вывод и изменение его статического поля static int t. В главной функции main() после вызова функции f () вызов метода Static<int>: :print() показывает, что статическое поле static int t — единственное, так как выводится значение, присвоенное полю в функции f (). Оно остается единственным даже для динамического объекта того же типа, что можно наблюдать, добавив в программу следующие строки:
// указатели!!
Static<int> *t = new Static<int>; t->print(); cout << endl; t->print(100); cout << endl; delete t;
Теперь проделаем то же самое, использовав модель явного инстанцирования: разделим модуль с шаблоном на два (интерфейс и реализацию) и добавим модуль с директивами инстанцирования (листинг 13.19).
Листинг 13.19. Статические элементы шаблона — модель с явным инстанцированием
// файл StaticField.h
#ifndef StaticField #define StaticField #include <iostream> template <class T> class Static
{ static T t; // зависимое имя
static int count; // независимое имя
public:
Static (){++count; } -Static (){--count; } static void print(T x = t);
// конструктор // деструктор
};
#endif
// -
#ifndef StaticFieldDef #define StaticFieldDef #include "StaticField.h"
файл StaticField.срр
// подключение определения шаблона
// определение статических элементов template <class Т> int Static<T>::count = 0; template <class T> T Static<T>::t = TO; template <> int Static<int>::t = 55; template <> double Static<double>::t = 155; template <class T> void Static<T>::print(T x) { std::cout << x <<" "<< count; t = x;
}
#endif
// модуль явного инстанцирования
#include "StaticField.срр" // подключение определений
template class Static<int>; template class Static<long>; template class Static<double>;
// модуль с функцией f()
#include "StaticField.h" // подключение интерфейса Шаблона
#include <iostream> using namespace std; Static<int> t; void f (void)
{ cout << "Inside f()-t "; t.printO; cout << endl; int у = 123;
cout << "Inside f()-t "; Static<int>::print(y); cout << endl;
}
// - модуль main.cpp
#include "StaticField.h" // подключение шаблона
#include <iostream> using namespace std;
void f(void); // объявление внешней функции
Static<long> г; // глобальный объект
int main()
{ Static<double>::print(); cout << endl;
Static<double>::print(234); cout << endl;
Static<double> r; // локальный объект
Static<double>::print(); cout << endl; // вывод для static long t Static<long>::print(); cout << endl; Static<long>::print(4321); cout << endl;
r.printO; cout << endl; // вывод для Static<double> г;
:: г.printO; cout << endl; // вывод для Static<long> r;
f();
// указатели!!
Static<int> *t = new Static<int>; t->print(); cout << endl; t->print(100); cout << endl; delete t; return 0;
}
Эта программа компилируется и компонуется без ошибок. Результаты, выводимые на экран, совпадают с результатами выполнения программы, реализованной в соответствии с моделью включения. |