现在的位置: 首页 > 综合 > 正文

程序调试--基本数据类型向CFile的串行化

2013年12月05日 ⁄ 综合 ⁄ 共 3243字 ⁄ 字号 评论关闭

程序代码:


程序执行流程:

1、CArchive构造,pFile为指向file的指针(一定不能NULL)nModeCArchive::storenBufSize取了默认值为4096lpBuf取了默认值为NULL。

 

 

在初始化的时候,m_lpBufStartm_lpBufMaxm_lpBufCurm_nBufSizem_bDirectBuffer这几个成员变量比较重要。m_lpBufStart是缓冲区起始地址,m_lpBufMax是缓冲区最大地址,m_lpBufCur是缓冲区当前地址,m_nBufSize是缓冲区大小,m_bDirectBuffer表明是否是直接缓冲(如CMemFile,直接存到内存中,不写入文件)。m_lpBufCur在读取数据的时候是指向m_lpBufMax,因为在开始读取时,m_lpBufCur == m_lpBufMax表明当前缓冲区已经读取完成,将会加载新的缓冲区,这样程序就从file中读取数据来填充缓冲区。

 

2、串行化长整型值。

 

这个函数是CArchive的成员函数,在afx.inl中定义。它先检查当前缓冲区是否还能容下待写入数据。如果空间不足,先调用CArchive::Flush()函数,将缓冲区数据写入到文件中。然后,将m_lpBufCur指针转换为BYTE*,直接写入数据。

CArchive::Flush()函数过程如下:

 

因为m_bDirectBuffer为FALSE,所以调用第一个if子句。检测当前缓冲区指针是否不等于缓冲区起始指针,如果不等则表明缓冲区中有数据,进而调用CFile::Write()将缓冲区数据写入到文件中。

 

3、CArchive析构。

显然,如果缓冲区中还有数据,CArchive直接析构将导致数据丢失,所以应该在析构时再刷新一次缓冲区。

 

 


一点额外的东西。

从CArchive的构造函数可以看出CArchive允许用户自己定义缓冲区,而非由CArchive自己来管理缓冲区。同时,要使用用户自定义缓冲区,该缓冲区大小应该大于128字节。见如下示例代码:

 

通过调试可以发现,CArchive将数据写入到了pBuffer所指的内存区中。

 

 

 

 

抱歉!评论已关闭.