CStdioFile

VC 专栏收录该内容
42 篇文章 0 订阅

本文讲解怎样利用CStdioFile对文件进行读写操作。

//-----------------------------------------------
// CStdioFile写文件示例
// 实现功能:1.如果文件存在,在文件末尾添加内容
//          2.如果文件不存在,则创建文件并添加内容
//-----------------------------------------------
CString cstrFileFullPath = "D:\\test.txt";

// 判断文件是否存在,如果存在则去掉只读属性
if (PathFileExists(cstrFileFullPath) && !PathIsDirectory(cstrFileFullPath))
{
    DWORD dwAttrs = GetFileAttributes(cstrFileFullPath);
    if (dwAttrs != INVALID_FILE_ATTRIBUTES
        && (dwAttrs & FILE_ATTRIBUTE_READONLY))
    {
        dwAttrs &= ~FILE_ATTRIBUTE_READONLY;
        SetFileAttributes(cstrFileFullPath, dwAttrs);
    }
}

// 打开文件
CStdioFile file;
BOOL ret = file.Open(cstrFileFullPath, 
    CFile::modeCreate | CFile::modeNoTruncate | CFile::modeWrite | CFile::shareDenyWrite);
if (!ret)
{
    AfxMessageBox("打开文件失败");
    return;
}
file.SeekToEnd();

//  写文件
file.WriteString("hello\n");
file.WriteString("kitty\n");

// 关闭文件
file.Close();

// 1.PathFileExists与PathIsDirectory需要引用头文件:#include "shlwapi.h"
// 2.CFile::modeCreate | CFile::modeNoTruncate的功用:
//   如果文件存在则打开,不清空文件内容
//   如果文件不存在则创建
// 3.CStdioFile默认是以文本方式打开文件的,所以写入文件时要换行只需写入"\n"
// 4.CFile::typeBinary指定CStdioFile以二进制方式打开文件

//-----------------------------------------------
// CStdioFile读文件示例
// 实现功能:打开已存在文件并逐行读取文件内容
//-----------------------------------------------
CString cstrFileFullPath = "D:\\test.txt";

// 判断文件是否存在
bool bFileExist = PathFileExists(cstrFileFullPath) 
&& (!PathIsDirectory(cstrFileFullPath));
if (false == bFileExist)
{
    return;
}

// 打开文件
CStdioFile file;
BOOL ret = file.Open(cstrFileFullPath,
    CFile::modeRead | CFile::shareDenyNone);
if (!ret)
{
    AfxMessageBox("打开文件失败");
    return;
}
file.SeekToBegin();

// 循环读取文件
CString cstrLine;
while (file.ReadString(cstrLine))
{
    AfxMessageBox(cstrLine);
}

// 关闭文件
file.Close();

//-----------------------------------------------
// 打开文件参数项
//-----------------------------------------------
CFile::modeCreate 
    --- 如果文件不存在则创建,如果文件存在则打开文件并清空文件内容
CFile::modeCreate | CFile::CFile::modeNoTruncate
    --- 如果文件不存在则创建,如果文件存在则打开文件并保留文件内容
CFile::shareDenyNone
    --- 允许其它进程对文件读写
CFile::shareDenyRead
    --- 不允许其它进程对文件进行读操作
CFile::shareDenyWrite
    --- 不允许其它进程对文件进行写操作
CFile::shareExclusive
    --- 以独占模式打开文件,不允许其它进程对文件进行读写附:

nOpenFlags共享和访问模式,指定当打开文件时进行的动作,可以将以下所列用OR(|)操作符联起来。至少应有一个访问权限和一个共享选项,modeCreate和modeNoInherit是可选的。值如下所示:
·CFile::modeCreate调用构造函数构造一个新文件,如果文件已存在,则长度变成0。
·CFile::modeNoTruncate此值与modeCreate组合使用。如果所创建的文件已存在则其长度不变为0。因而此文件被打开,或者作为一个新文件或者作为一个已存在的文件。这将是很有用的,例如当打开一个可能存在也可能不存在的文件时。这个选项也可用于CStdioFile.
·CFile::modeRead打开文件仅供读。
·CFile::modeReadWrite打开文件供读写。
·CFile::modeWrite打开文件仅供写。
·CFile::modeNoInherit阻止文件被子进程继承。
·CFile::ShareDenyNone不禁止其它进程读或写访问,打开文件。如果文件已被其它进程以兼容模式打开,则Create失败。
·CFile::ShareDenyRead打开文件,禁止其它进程读此文件。如果文件已被其它进程以兼容模式打开,或被其它进程读,则Create失败。
·CFile::ShareDenyWrite打开文件,禁止其它进程写此文件。如果文件已被其它进程以兼容模式打开,或被其它进程写,则Create失败。
·CFile::ShareExclusive以独占模式打开文件,禁止其它进程对文件的读写。如果文件已经以其它模式打开读写(即使被当前进程),则构造失败。
·CFile::ShareCompat此标志在32位MFC中无效。此标志在使用CFile::Open时映射为CFile::ShareExclusive。
·CFile::typeText对回车换行设置特殊进程(仅用于派生类)。
·CFile::typeBinary设置二进制模式(仅用于派生类)。 
  • 0
    点赞
  • 0
    评论
  • 2
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

©️2021 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值