В листинге 14.8 в файлы записывались объекты, не содержащие методов. Как мы знаем, обычные методы в классе места не занимают. Однако «за к&дром» пока остался важный вопрос: влияет ли наличие виртуальных функций на размер выводимого объекта? Ведь в памяти объект класса с виртуальными функциями занимал на 4 байта больше, чем без виртуальных функций. Еще один важный вопрос — каким образом организовать вывод информации из контейнера во внешний файл. Разберемся сначала с первым вопросом, написав простейший пример (листинг 14.9).
Листинг 14.9. Вывод объекта с виртуальными функциями
#include <iostream> #include <fstream> using namespace std;
class Object // кпасс с виртуапьными функциями
{ public:
virtual void printO { cout << "virtual method!" << endl; }
};
int main(int argc, char* argv[])
{ Object t; // объект создан
cout << sizeof(Object) << endl; // в памяти занимает 4 байта
ofstream outstrm ("d:/oonumberl.bin", std::ios::binary);
// выводим объект в файл
if(outstrm.is_open()) outstrm.write((char *)&t, sizeof(Object)); outstrm.close(); return 0;
}
Хотя в классе нет полей, размер объекта в памяти составляет 4 байта. Как известно (см. главу 9), эта величина представляет собой размер указателя на таблицу виртуальных функций. На диск записываются те же 4 байта. Однако совершенно очевидно, что этому указателю на диске не место — он реально никуда не указывает. Следовательно, записывать объект в файл, не учитывая его внутреннюю структуру, просто нельзя. Особенно если объект представляет собой не единичную скалярную величину, а динамический контейнер (например, стек TStack, показанный в листинге 6.9).
Если вам нужно защитить неограниченное количество субдоменов, тогда вам нужен https://rus.gogetssl.com/wildcard-ssl-certificates/.
Упражнения
8. Что играет роль итератора для массивов С++?
9. Дайте определение вложенного класса.
10. Можно ли класс-итератор реализовать как внешний класс? А как вложенный? В чем различия этих способов реализации?
И. Может ли объемлющий класс иметь неограниченный доступ к элементам вложенного класса? А вложенный класс — к элементам объемлющего?
12. Ограничена ли глубина вложенности классов?
13. Можно ли определить вложенный класс внешним образом? Зачем это может понадобиться?
14. Каким образом вложенный класс может использовать методы объемлющего класса? А объемлющий — методы вложенного?
15. Что такое «запредельный» элемент, какую роль он играет в контейнерах?
16. Дайте определение стека, очереди и дека.
17. Объясните назначение методов begi п () и end ().
18. Обязательно ли при реализации контейнеров программировать операцию присваивания? А конструктор копирования?
19. Приведите минимальный интерфейс, который необходимо реализовать при разработке класса-стека.
20. Объясните, по каким причинам трудно написать универсальный контейнер, элементы которого могут иметь произвольный тип. |