1. 串行化和并行化的概念:
1) 问题背景——内存保存数据和磁盘保存数据的不同:
i. 内存可以通过CPU进行寻址,因此内存中有指针这个概念,因此内存中的数据可以用非常复杂的数据结构组织;
ii. 磁盘容量过于庞大,并且不能直接由CPU寻址,因此磁盘中没有指针这个概念,磁盘中的数据只能线性的按顺序一个个存储起来;
iii. 因此说,内存中由数据结构组织起来的数据是立体的、复杂的,也就是并行化(有一种立体的感觉)的,而磁盘中的数据仅仅是简单的、线性的,也就是串行化的(像图这样的数据结构因为磁盘中没有指针的维护也只能线性地存取);
2) 因此,将内存中的并行化的数据写入磁盘就是一种数据的串行化过程,而将数据从串行化的磁盘读入内存就是一种数据的并行化;
3) MFC的串行化支持:
i. 由于MFC的CFile类向磁盘读写数据要使用Read和Write,使用起来非常不方便,因此MFC又提供了一个CArchive类来支持串行化和并行化;
ii. Archive即存档的意思,其实CArchive类即支持磁盘写入也支持读出,因此该词就理解为文档的意思,这也是MFC的文档/视图结构的基础,程序数据通过文档保存在磁盘中,这种保存和读取就是一种串并行化的行为;
iii. 其中的主要步骤:首先将CArchive对象和一个文件CFile对象关联起来,然后就可以利用CArchive重载过的<<和>>进行数据输入输出(是指是读写磁盘),而这过程中CArchive底层调用了CFile的Read和Write函数,避免了程序员直接面对较为麻烦的CFile成员函数;
!!!其实CArchive类最最牛逼也最最高效的地方就是可以创建用户自定义的串行化类,然后直接就用<<和>>进行磁盘读写就行了,非常方便:
CArchive ar;
... // 将ar和具体的文件关联起来
CMyObject myObj; // 自定义的类符合串行化的协议
...
ar << myObj;
2. 串行化的基本用法:
1) 利用CArchive的构造函数来和具体的文件相关联:
i. 构造函数:CArchive::CArchive