Запись и восстановление объектов
Одна из задач, решаемых программистом при разработке приложений, которые могут создавать и редактировать документы различных типов, например текстовые или графические, заключается в том, чтобы предоставить пользователю возможность записать внутреннее представление документа в файл и восстановить его.
Чтобы облегчить программисту решение этой задачи, библиотека классов MFC определяет механизм записи и восстановления объектов (serialization). Поддержка механизма записи и восстановления объектов осуществляется средствами класса CObject.
Классы, наследованные от CObject также могут обеспечивать работу механизма записи и восстановления объектов. Для этого при объявлении класса надо указать макрокоманду DECLARE_SERIAL, а при определении – макрокоманду IMPLEMENT_SERIAL.
Макрокоманду DECLARE_SERIAL надо поместить перед описанием вашего класса во включаемом файле. Непосредственно после имени макрокоманды надо указать имя класса – class_name:
DECLARE_SERIAL(class_name)
Макрокоманду IMPLEMENT_SERIAL надо указать перед определением класса в файле исходного текста приложения, имеющего расширение CPP. Прототип макрокоманды IMPLEMENT_SERIAL представлен ниже:
IMPLEMENT_SERIAL(class_name, base_class_name, wSchema)
Параметр class_name определяет имя вашего класса, base_class_name – имя базового класса из которого непосредственно наследуется ваш класс. Последний параметр wSchema – это число типа UINT, определяющее версию программы. Если вы разработаете новую версию своего приложения и измените набор данных, которые необходимо записать в файл, измените параметр wSchema.
В классе должны быть определены специальные методы для записи и восстановления состояния объектов этого класса. Обычно эти методы сохраняют и восстанавливают элементы данных из класса. Таким образом, объекты класса сами отвечают за то, как они сохраняют и восстанавливают свое состояние.
Методы, сохраняющие и восстанавливающие состояние класса, взаимодействуют с объектом класса CArchive, который осуществляет непосредственную запись и чтение информации из файла на диске.
Класс CObject содержит виртуальный метод Serialize , отвечающий за запись и чтение объектов классов, наследованных от класса CObject:
virtual void Serialize(CArchive& ar) throw(CMemoryException) throw(CArchiveException) throw(CFileException);
В качестве параметра ar, методу передается указатель на объект класса CArchive , используемый для записи и восстановления его состояния из файла. Чтобы узнать, какую операцию должен выполнить метод Serialize, воспользуйтесь методами CArchive::IsLoading или CArchive::IsStoring.
Новая реализация метода Serialize должна первым делом вызвать метод Serialize базового класса. Это гарантирует, что при сохранении и восстановлении объекта будут обработаны все элементы всех базовых классов.
Метод Serialize вызывается объектами класса CArchive когда приложение читает или записывает этот объект, вызывая методы CArchive::ReadObject или CArchive::WriteObject. Сразу отметим, что с методами CArchive::ReadObject и CArchive::WriteObject непосредственно связаны операторы записи << и чтения >>.
Перед тем как создать объект класса CArchive, необходимо создать объект класса CFile. Связывая с объектом CFile файл на диске, имейте в виду, что если вы желаете записать объект файл, то файл надо открыть на запись, а если надо считать файл с диска и загрузить из него данные в объект, открыть файл надо для чтения.
Конструктор класса CArchive имеет следующий вид:
CArchive(CFile* pFile, UINT nMode, int nBufSize = 512, void* lpBuf = NULL) throw(CMemoryException, CArchiveException, CFileException);
Параметр pFile должен содержать указатель на объект класса CFile, из которого будут считываются или записываться данные. Перед вызовом конструктора файл, связанные с объектом pFile должен быть уже открыт.
Параметр nMode определяет, будут данные записываться в файл или считываться из него. Параметр nMode может принимать одно из трех значений CArchive::load, CArchive::store или CArchive::bNoFlushOnDelete, описанных в следующей таблице.
Для операций чтения и записи в файл класс CArchive выполняет буферизацию. Размер этого буфера определяется необязательным параметром nBuf Size в байтах. Если вы не укажите размер буфера, используется буфер размером 512 байт.
Конструктор класса CArchive сам получает у операционной системы блок оперативной памяти для буфера. Однако с помощью необязательного параметра lpBuf вы можете предоставить собственный буфер. В этом случае параметр nBufSize должен указывать размер этого буфера.
Созданный вами объект класса CArchive можно будет использовать только для записи или только для чтения. Если вам надо сначала считать данные, а потом записать, следует создать для этого два отдельных объекта класса CArchive.
Не используйте методы класса CFile для доступа к файлу во время его использования совместно с объектами класса CArchive. Запись, чтение или перемещение указателя файла может вызвать нарушения во внутренней структуре файла архива.
Когда созданный объект класса CArchive передается функции Serialize, вы можете определить, предназначен он для записи или для чтения, вызвав метод CArchive::IsLoading или CArchive::IsStoring.
Метод IsStoring возвращает ненулевое значение, если данный объект предназначен для записи в файл и нуль в противном случае:
BOOL IsStoring() const;
Метод IsLoading является полной противоположностью метода IsStoring. Он возвращает ненулевое значение, если данный объект предназначен для чтения из файла и нуль в противном случае. Вы можете использовать любой метод IsLoading или IsStoring.
Основное предназначение объекта класса CArchive заключается в том, что объекты вашего класса могут посредством него записать свое состояние в файл, а затем при необходимости восстановить его. Для этого в классе CArchive определены операторы записи в файл << и чтения из файла >>. Вы также можете использовать методы WriteString, Write, ReadString и Read. Опишем эти операторы и методы более подробно.
- Фролов а.В., Фролов г.В. Библиотека системного программиста
- Программирование для Windows 95 и Windows nt Введение
- Поддержка сети Internet
- Язык моделирования виртуальной реальности
- Игровое sdk
- Набор ocx объектов
- Как связаться с авторами
- Благодарности
- Ввод/вывод
- Константы
- Распределение памяти
- Операторы new и delete
- Перегрузка имен функций
- Задание параметров функции по умолчанию
- Встраивание
- Ключевое слово this
- Разграничение доступа к элементам класса
- Методы, входящие в класс
- Конструкторы и деструкторы класса
- Методы, не изменяющие объекты класса
- Статические методы
- Общие члены объектов класса
- Дружественные функции и дружественные классы
- Дружественные функции
- Дружественные классы
- Наследование
- Единичное наследование
- Множественное наследование
- Разграничение доступа к элементам базового класса
- Переопределение методов базового класса
- Виртуальные методы
- Абстрактные классы
- Структуры
- Шаблоны
- Шаблоны в mfc
- Перегрузка операторов
- Обработка исключительных ситуаций
- Операторы try, throw и catch
- Листинг 1.1. Файл Exception.Cpp
- Универсальный обработчик исключений
- Тип исключения
- 2. Введение в mfc
- Классы библиотеки mfc
- Самый базовый класс mfc (класс cObject)
- Основа структуры приложения (класс cCmdTarget)
- Подзадачи приложения (классы cWinThread и cWinApp)
- Документ приложения (класс cDocument)
- Шаблон документов (классы cDocTemplate, cSingleDocTemplate и cMultiDocTemplate)
- Окна (класс cWnd)
- Исключения (класс cException)
- Массивы, списки и словари
- Файловая система (класс cFile)
- Контекст отображения (класс cdc)
- Объекты графического интерфейса (класс cGdiObject)
- Меню (класс cMenu)
- Базы данных (классы для работы с базами данных)
- Синхронизация задач приложения (класс cSyncObject)
- Сокеты (классы cAsyncSocket и cSocket)
- Классы, не имеющие базового класса
- Простые классы
- Архивный класс (класс cArchive)
- Информация о классе объекта (структура cRuntimeClass)
- Отладка приложения (классы cDumpContext, cMemoryState)
- Печать документа (класс cPrintInfo)
- Первое приложение mfc
- Окно Project Workspace
- Листинг 2.1. Файл mfHello.Cpp
- Средства ClassView
- Добавление к классу нового метода
- Добавление к классу нового элемента данных
- Просмотр дерева наследования классов
- Редактирование методов класса
- Редактирование элементов данных класса
- Приложение с единственным окном
- Листинг 2.2. Файл mfStart.Cpp
- Листинг 2.3. Файл mfStartApp.H
- Оконные сообщения
- Сообщения от органов управления
- Командные сообщения
- Макрокоманда on_registered_message
- Макрокоманда on_message
- Макрокоманда on_command
- Макрокоманда on_command_range
- Макрокоманда on_update_command_ui
- Макрокоманда on_update_command_ui_range
- Макрокоманда on_control_range
- Забегая вперед
- Приложение mfMenu
- Листинг 2.7. Файл mfMenu.Cpp
- Ресурсы приложения
- Создание меню для приложения mfMenu
- Листинг 2.8. Файл mfMenuRes.H
- Листинг 2.9. Файл mfMenuRes.Rc
- Долгий путь сообщения
- Листинг 2.10. Файл mfMessage.Cpp
- Листинг 2.11. Фрагмент файла mfMessage.Rc
- Листинг 2.12. Файл resource.H
- Диалоговая панель
- Приложение с модальной диалоговой панелью
- Листинг 2.13. Файл mfDialog.Cpp
- Vertical Scroll Bar Вертикальная полоса просмотра
- Листинг 2.14. Фрагмент файла mfDlgRes.Rc
- Листинг 2.15. Файл resource.H
- Главный класс приложения
- Класс диалоговой панели
- Обмен данными
- Приложение с немодальной диалоговой панелью
- 3. Некоторые классы mfc
- Класс cObject – основной класс mfc
- Конструкторы класса
- Оператор присваивания
- Диагностика
- Проверка целостности объектов класса
- Получение дампа объекта класса
- Сохранение и восстановление состояния объекта
- Метод IsSerializable
- Виртуальный метод Serialize
- Информация о классе
- Виртуальный метод GetRuntimeClass
- Метод IsKindOf
- Класс cPoint – точка на плоскости
- Класс cSize – относительные координаты
- Класс cString – текстовые строки
- Конструктор класса
- Коллекции
- Массивы – шаблон cArray
- Списки – шаблон cList
- Словари – шаблон cMap
- Класс cTime – дата и время
- Файловая система – класс cFile
- Открытие и создание файлов
- Идентификатор открытого файла
- Закрытие файлов
- Чтение и запись файлов
- Метод Flush
- Операции с файлами
- Блокировка
- Позиционирование
- Характеристики открытого файла
- Файловая система – классы cMemFile и cStdioFile
- Модификация класса cMemFile
- Файловая система – класс cStdioFile
- Приложение TestFile
- Листинг 3.1. Файл TestFile.Cpp
- Листинг 3.2. Файл fsystem.Dat
- Исключения – класс cException
- Класс cException
- Класс cMemoryException
- Класс cFileException
- Приложение Except
- Листинг 3.3. Файл Except.Cpp
- Класс cArchiveException
- Класс cNotSupportedException
- Класс cResourceException
- Класс cUserException
- Запись и восстановление объектов
- Запись в архивный файл
- Чтение из архивного файла
- Многозадачные приложения
- 4. Приложение с главной диалоговой панелью
- Создание приложения средствами mfc AppWizard
- Приложение Dialog
- Имена, используемые mfc
- Ресурсы приложения
- Icons Пиктограммы
- Version information Сведения о версии приложения
- Диалоговые панели приложения Dialog
- Пиктограмма
- Исходные тексты приложения
- Главный класс приложения dialog
- Листинг 4.1. Файл Dialog.H
- Листинг 4.2. Файл Dialog.Cpp
- Главный объект приложения
- Метод InitInstance
- Класс главной диалоговой панели приложения
- Листинг 4.3. Файл DialogDlg.H
- Листинг 4.4. Файл DialogDlg.Cpp
- Конструктор класса cDialogDlg
- Метод DoDataExchange
- Метод OnInitDialog
- Метод OnSysCommand (системное меню)
- Метод OnPaint (отображение пиктограммы приложения)
- Метод OnQueryDragIcon
- Файлы StdAfx.Cpp и StdAfx.H
- Листинг 4.5. Файл StdAfx.Cpp
- Листинг 4.6. Файл StdAfx.H
- Средства ClassWizard
- Создание нового класса
- Листинг 4.7. Файл NewClass.H
- Листинг 4.8. Файл NewClass.Cpp
- Включение в класс новых методов
- Включение в класс новых элементов данных
- Просмотр характеристик класса
- 5. Однооконный интерфейс
- Модель “документ – окно просмотра ”
- Процедура создания однооконного приложения
- Приложение Single
- Ресурсы приложения
- Шаблон меню
- Панель управления toolbar
- Пиктограмма
- Диалоговая панель
- Общие замечания о ресурсах приложения
- Классы приложения
- Класс cSingleApp
- Главный объект приложения
- Конструктор класса cSingleApp
- Метод InitInstance
- Метод OnAppAbout
- Класс cSingleDoc
- Конструктор и деструктор класса cSingleDoc
- Методы OnNewDocument и Serialize
- Методы AssertValid и Dump
- Класс cSingleView
- Конструктор и деструктор класса cSingleView
- Метод GetDocument
- Метод PreCreateWindow
- Метод OnDraw
- Методы OnPreparePrinting, OnBeginPrinting и OnEndPrinting
- Методы AssertValid и Dump
- Класс cMainFrame
- Конструктор и деструктор класса cMainFrame
- Метод OnCreate
- Панель управления и панель состояния
- Панель управления
- Панель состояния
- Метод PreCreateWindow
- Методы AssertValid и Dump
- Обработка командных сообщений
- Порядок обработки сообщений
- Главное окно однооконного приложения
- Окно просмотра
- Документ
- Диалоговая панель
- Командные сообщения и приложение Single
- Изменение порядка обработки сообщений
- Стандартные команд ные сообщения
- Командные сообщения с идентификаторами id_file_
- Командные сообщения с идентификаторами id_edit_
- Командные сообщения с идентификаторами id_window_
- Командные сообщения с идентификаторами id_app_
- Командные сообщения с идентификаторами id_help_
- Командные сообщения с идентификаторами id_view_
- Простейший графический редактор
- Создание нового документа
- Сохранение и восстановление документа на диске
- Для забывчивых пользователей
- Простейший текстовый редактор
- Заключение
- Литература