MFC提供了非常方便的串行化函数Serialize()。利用这个机制可以很方便的对文档进行存取和读取。
Serialization就是面向对象世界里面的永久生存机制,对象必须能够永久生存,也就是他们必须能够在程序结束时存储到文件当中,并且能够在程序重新激活时在恢复过来,存储和恢复对象的过程在MFC称之为Serialization,负责这项重要任务的是MFC Object类中的一个名为Serialize()的虚函数,文件的读写操作均通过它来方便的完成。
一个类要支持Serializable,必须遵循以下步骤:
之后,该类就可以被Serializable。
譬如我们新建一个MFC应用程序,为了方便处理数据,我们在程序中单独创建自己的类MyClass:
1
2
3
4
5
6
7
8
9
10
|
MyClass: public CObject { DECLARE_SERIAL(MyClass) //很重要一定要加上 public : virtual void Serialize(CArchive& ar); public : int m_iVal; float m_fVal; }; |
在实现文件中:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
IMPLEMENT_SERIAL(MyClass,CObject,1) void MyClass::Serialize(CArchive& ar) { if (ar.IsLoading()) { //从文件中读取数据到内存中 ar >> m_iVal; ar >> m_fVal; } else if (ar.IsStoring()) { ar << m_iVal; ar << m_fVal; } } |
然后在MFC程序的C**Doc类中添加一个MyClass类型的对象myclass:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
class C***Doc : public CDocument { public : C***Doc(); DECLARE_DYNCREATE(C***Doc) public : MyClass myclass; public : virtual void Serialize(CArchive& ar); ******* } |
并且在C***Doc类的Serialize()函数中调用我们的myclass对象的Serialize函数就可以永久保存myclass对象了:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
IMPLEMENT_DYNCREATE(C***Doc, CDocument) BEGIN_MESSAGE_MAP(C***Doc, CDocument) END_MESSAGE_MAP() IMPLEMENT_SERIAL(MyClass,CObject,1); void C***Doc::Serialize(CArchive& ar) { if (ar.IsStoring()) { myclass.Serialize(ar); } else { myclass.Serialize(ar); } } |
当我们新建一个基于文档的MFC程序时,向导会自动为我们创建一些菜单,点击菜单的保存或者打开文件按钮时,内部机制自动触发Serialize函数调用,那么怎样在程序中自己触发Serialize呢?
剖开文件保存和打开内部机制(详见深入浅出MFC),对于读取文件,会得到类似这样的调用来触发Serialize加载机制:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
CFileException fe; CFile::modeRead | CFile::shareDenyWrite, &fe); DeleteContents(); SetModifiedFlag(); CArchive loadArchive(pFile,CArchive::load ); loadArchive.m_pDocument= this ; loadArchive.m_bForceFlat=FALSE; CWaitCursor wait; if (pFile->GetLength()!=0) Serialize(loadArchive); loadArchive.Close(); ReleaseFile(pFile,FALSE); |
类似的,可以使用下面的操作来触发Serialize保存机制:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
CFileException fe; CFile::modeWrite | CFile::shareDenyWrite, &fe); DeleteContents(); SetModifiedFlag(); CArchive saveArchive(pFile,CArchive::store ); saveArchive.m_pDocument= this ; saveArchive.m_bForceFlat=FALSE; CWaitCursor wait; if (pFile->GetLength()!=0) Serialize(saveArchive); saveArchive.Close(); ReleaseFile(pFile,FALSE); |
用户377235 2015-7-23 10:05
头文件部分怎么填啊?照你这么写代码,编译还是出错啊