工作以来一直在做.NET方面的程序,以前自学的C++和MFC许久未碰了。今天恰逢周末休息,闲来翻看一本MFC的书,对序列化(Serialize)部分又研究了一番。在这次故地重游之旅中,我又再一次赞叹于Microsoft Application Framework小组专家们的聪明才智,为开发人员创造出了一个如此优秀的Framwork。
人们都说,“发表是最好的回忆”,我也不妨在此回忆一番,记录下这“MFC 序列化追忆之旅”。
下面是我写的一个MFC 序列化应用例程。展现了如何将一组CBook类型的对象写入文件以及如何再从文件中读取,使“对象永续(object persistence)”。
Book.h
#include <afxwin.h>
class CBook : public CObject { DECLARE_SERIAL(CBook)
public: CString m_strName; CString m_strAuthor; CString m_strPress;
public: CBook() { // 要使CBook对象实现序列化,必须定义默认构造函数 }
CBook(CString strName, CString strAuthor, CString strPress) { m_strName = strName; // 书名 m_strAuthor = strAuthor; // 作者 m_strPress = strPress; // 出版社 }
void Serialize(CArchive &); // 重载基类的Serialize函数 };
Book.cpp
#include "Book.h"
IMPLEMENT_SERIAL(CBook, CObject, 1)
void CBook::Serialize(CArchive &ar) { CObject::Serialize(ar); if(ar.IsStoring()) { ar << m_strName << m_strAuthor << m_strPress; } else { ar >> m_strName >> m_strAuthor >> m_strPress; } } |
主程序
CBook book1("Programming Windows", "Charles Petzold", "Microsoft Press"); CBook book2("Programming Windows with MFC", "Jeff Prosise", "Microsoft Press"); int nCount = 2;
// 序列化 CFile fileStore(_T("mybooks.dat"), CFile::modeWrite | CFile::modeCreate); CArchive arStore(&fileStore, CArchive::store); CBook* pBooksStore[2] = { &book1, &book2 }; arStore << nCount; for (int i=0; i<nCount; ++i) { arStore << pBooksStore[i]; } fileStore.Close();
// 反序列化 CFile fileLoad(_T("mybooks.dat"), CFile::modeRead); CArchive arLoad(&fileLoad, CArchive::load); arLoad >> nCount; CBook* pBooksLoad = new CBook[nCount]; for (int i=0; i<nCount; ++i) { arLoad >> pBooksLoad[i]; } fileLoad.Close(); |
MFC序列化注意事项:
·要想使某一类型能被序列化,在它类型声明文件(头文件,Book.h)和类型定义文件(Book.cpp)中要分别使用DECLARE_SERIAL和IMPLEMENT_SERIAL宏。
·能被序列化的只能指针型,不能是值型(pBooksStore数组中包含的就是两个CBook类型的指针)。  
说明:本教程来源互联网或网友上传或出版商,仅为学习研究或媒体推广,wanshiok.com不保证资料的完整性。
|