CStdioFile类的声明保存在afx.h头文件中。
CStdioFile类继承自CFile类,CStdioFile对象表示一个C运行函数fopen打开的的流式文件。流式文件是被缓冲的,而且可以以文本方式(默认)或者二进制方式打开。
CStdioFile类不支持CFile类中的Duplicate、LockRange、UnlockRange函数,如果你使用了,会得到C Not Supported Exception类的错误。
CStringFile类默认的是按照Text模式操作文件。
CFile 类默认的是按照二进制模式操作文件。
这里大致说明一下二进制模式和Text模式的区别。
二进制模式:对于一行的结尾我们必须输入'\r\n',才能表示回车换行的效果。
Text模式:'\r'回车的工作是自动完成的,我们只需要写入'\n'即可。在使用Text模式时从外部读入文件时,'\r\n'会被翻译成'\n',写入文件时,我们对于回车换行只需提供'\n',即可,'\r\n'会被写入到文件中。
成员变量
m_pStream成员变量:打开文件的指针。
构造函数
CStdioFile();
CStdioFile(FILE *pOpenStream);
CStdioFile(LPCTSTR lpFileName, UINT nOpenFlags);
throw(CFileException);
FILE *pOpenStream:指的是c运行函数fopen调用后返回的文件指针。
LPCTSTR lpFileName:指的是被打开的文件(绝对地址或相对地址)
UINT nOpenFlags:指的是CFile类中所描述的打开文件的方式。
读函数
virtual LPTSTR ReadString(LPTSTR lpsz, UINT nMax);
throw(CFileException);
如果使用该函数读取文本文件,当遇到'\r\n',停止读取,并去掉'\r',保留'\n',并在字符串尾部增加'\0',nMax的长度包含有'\0'字符,实际的分析如下:
如果nMax <= 字符数,读取(nMax-1)个字符+0x00;
如果nMax = 字符数 + 1,读取nMax个字符+0x00;
如果nMax > 字符数,读取nMax个字符+0x0A('\n') + 0x00;
如果文件有多行,则当文件没有读完时,返回NOT NULL,读到文件尾,返回NULL。
BOOL ReadString(CString& rString);
throw(CFileException);
读取一行文本到rString中,遇到回车换行符停止读取,回车和换行符均不读到rString中,尾部也不添加'0x00'。如果文件有多行,则当文件没有读完时,返回TRUE,读到文件尾,返回FALSE。
写函数
virtual void WriteString(LPTSTR lpsz);
throw(CFileException);
将缓冲区中的数据写入到与CStdioFile对象相关联的文件中,不支持CString类型数据写入,结束的'\0'不被写入到文件中,lpsz缓冲区中的所有换行符被替换为回车换行符,即'\n'转换为'\r\n'。
三、CStdioFile类编程原理
假如要进行的文件操作只是简单的读写整行的字符串,那么最好使用CStdioFile。首先把文本文件的每行数据读到一个缓冲区,然后使用sscanf把它转化为字符格式。
例如在一个txt文件里每一行数据格式是这样的:
A1 A2 A3 A3 ......An
那么读取的主体代码是:
CStdioFile File; // 定义一个CStdioFile类变量File
CString FileData; // 定义一个CString,作为一个缓冲区
//定义n个临时字符串变量,大小依据实际情况,这里暂设为10
char TempStr1[10],TempStr2[10]......TempStrN[10];
File.ReadString(FileData); // 将一行数据读到缓冲区
//将该行数据的n个字符读到n个临时字符串变量
sscanf(FileData,"%s %s %s %s ......%s",TempStr1,TempStr2......TempStrN);
这种读法的一个好处是对文本格式要求不严,如下面的格式也可以
(前面可有未知个空格) A1 A2 (两个数据之间也可有未知个空格) A3 A3 ......An
CStdioFile类的用法(除此之外还有CFile,CArchive,CMemFile等等)。
MFC中使用CStdioFile类封装了C++运行时刻文件流的操作,流文件采用缓冲方式,支持文件模式和二进制模式文件操作,默认方式为文本模式。
CStdioFile类从CFile类继承,具有如下三个构造函数:
1、CStdioFile():建立一个CStdioFile类的对象,但不打开文件;
2、CStdioFile(FILE* pOpenStream):建立一个CStdioFile类的对象,并将该对象同一个已经打开的文件相联系;
3、CStdioFile(LPCTSTR lpszFileName, UINT nOpenFlags):建立一个CStdioFile类的对象,同时打开一个文件,nOpenFlags是打开文件的方式,它可以取值如下所述:
·CFile::modeCreate:创建新文件,并覆盖已有文件
·CFile::modeRead:以只读方式打开文件
·CFile::modeReadWrite:以读/写方式打开文件
·CFile::modeWrite:以只写方式打开文件
·CFile::shareExclusive:不允许其他进程读/写文件
·CFile::typeText:表示以文本方式打开文件
·CFile::typeBinary:表示以二进制方式打开文件
以上是几种常用的打开方式,还有另外几种可以去查阅相关资料。例如你可以这样创建一个新文件:
CStdioFile ioFile("新文本.txt", CFile::modeCreate|CFile::modeWrite);或者
CStdioFile ioFile;
ioFile.Open("新文本.txt", CFile::modeCreate|CFile::modeWrite);
表示创建一个名为“新文本”扩展名为TXT的只写文件,另外因为没有说明,默认为以文本方式打开而不是二进制方式。文件的关闭:ioFile.Close();
CStdioFile类中有两种特殊的读/写文件的方法,ReadStrng和WriteString,分别读出或写入一个文本行。例如使用 WriteString时,可以这样使用:
CString str = "这是一行文本\n";
ioFile.WriteString(str);
若要达到同样的目的,对应CFile而言,则应这样定义str = "这是一行文本\r\n"。
ReadString有两种重载的用法,可以指定读出的字符数,也可以不指定,如果在读文件过程中发生异常,将产生CFileException异常。