当前位置:编程学习 > C/C++ >>

利用序列化进行文件读写

 

在很多应用中我们需要对数据进行保存,或是从介质上读取数据,这就涉及到文件的操作。我们可以利用各种文件存取方法完成这些工作,但MFC中也提供了一种读写文件的简单方法——“序列化”。序列化机制通过更高层次的接口功能向开发者提供了更利于使用和透明于字节流的文件操纵方法,举一个例来讲你可以将一个字串写入文件而不需要理会具体长度,读出时也是一样。你甚至可以对字符串数组进行操作。在MFC提供的可自动分配内存的类的支持下你可以更轻松的读/写数据。你也可以根据需要编写你自己的具有序列化功能的类。

序列化在最低的层次上应该被需要序列化的类支持,也就是说如果你需要对一个类进行序列化,那么这个类必须支持序列化。当通过序列化进行文件读写时你只需要该类的序列化函数就可以了。

怎样使类具有序列化功能呢?你需要以下的工作:

  • 该类从CObject派生。
  • 在类声明中包括DECLARE_SERIAL宏定义。
  • 提供一个缺省的构造函数。
  • 在类中实现Serialze函数
  • 使用IMPLEMENT_SERIAL指明类名和版本号

下面的代码建立了一个简单身份证记录的类,同时也能够支持序列化。

in H
struct strPID
{
         char szName[10];
         char szID[16];
         struct strPID* pNext;
};
class CAllPID : public CObject
{
public:
         DECLARE_SERIAL(CAllPID)
         CAllPID();
         ~CAllPID();
         
public:// 序列化相关      
         struct strPID* pHead;
         //其他的成员函数
         void Serialize(CArchive& ar);
};
 
in CPP

		
	
补充:软件开发 , C语言 ,
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,