不可或缺 Windows Native (14) - C++: 文件

时间:2023-03-08 20:07:54

[源码下载]

不可或缺 Windows Native (14) - C++: 文件

作者:webabcd

介绍
不可或缺 Windows Native 之 C++

  • 文件

示例
CppIO2.h

#pragma once 

#include <string>

using namespace std;

namespace NativeDll
{
class CppIO2
{
public:
string Demo(string rootPath);
};
}

CppIO2.cpp

/*
* 文件
*/ #include "pch.h"
#include "CppIO2.h" #include <fstream> // ifstream(继承自istream), ofstream(继承自ostream) using namespace NativeDll; void cppio2_demo1();
void cppio2_demo2();
void cppio2_demo3();
void cppio2_demo4(); string _rootPath; string CppIO2::Demo(string rootPath)
{
_rootPath = rootPath; // 写入文本文件
cppio2_demo1(); // 读取文本文件
cppio2_demo2(); // 写入二进制文件
cppio2_demo3(); // 读取二进制文件
cppio2_demo4(); return "演示文件的保存路径:" + _rootPath;
} // 写入文本文件
void cppio2_demo1()
{
string fileName = _rootPath + "\\cpp_file_demo1.txt"; // 打开文件
// ofstream outfile;
// outfile.open(fileName, ios::out); // 打开文件也可以这样写
ofstream outfile(fileName, ios::out); // 第 2 个参数是文件的输入输出方式(多个用“|”分隔),其说明参见后面的注释
// 如果既想写又想读就用 fstream if (!outfile) // 如果文件打开失败,返回值为 0
{
// err
} for (int i = ; i < ; i++)
{
// 写入文本数据
outfile << "abc" << "\n";
} // 格式化写入的文本数据
outfile << hex << << std::endl; // 关于格式化请参见:CppIO1.cpp // 关闭文件
outfile.close();
} // 读取文本文件
void cppio2_demo2()
{
string fileName = _rootPath + "\\cpp_file_demo1.txt"; char buf[];
string result;
ifstream infile(fileName, ios::in); // 第 2 个参数是文件的输入输出方式(多个用“|”分隔),其说明参见后面的注释
// 如果既想写又想读就用 fstream // 文件打开成功,说明这个文件之前是存在的
if (infile.is_open())
{
// 返回下一个字符,但是文件内部位置指针不变
char c = infile.peek(); // 如果返回的字符是文件结束符,则其值为 EOF // 文件正常,且文件内部位置指针不在结尾
while (infile.good() && !infile.eof()) // eof - end of line
{
memset(buf, , ); // 清空 buf
infile.getline(buf, ); // 读当前文件内部位置指针所指的一行数据给 buf, 然后文件内部位置指针指向下一行 result += buf;
result += "\n";
} infile.close();
}
} // 写入二进制文件
void cppio2_demo3()
{
struct employee
{
int num;
char name[];
} w[] = { { , "wanglei" }, { , "webabcd" }, { , "diandian" } }; string fileName = _rootPath + "\\cpp_file_demo2.b";
ofstream outfile(fileName, ios::binary); // 第 2 个参数是文件的输入输出方式(多个用“|”分隔),其说明参见后面的注释
// 如果既想写又想读就用 fstream
if (!outfile)
{
// err
} for (int i = ; i < ; i++)
{
// 写入数据(要将地址转换为 char* 类型指针)
outfile.write((char *)&w[i], sizeof(w[i]));
} outfile.close();
} // 读取二进制文件
void cppio2_demo4()
{
struct employee
{
int num;
char name[];
} r[]; string fileName = _rootPath + "\\cpp_file_demo2.b";
ifstream infile(fileName, ios::binary); // 第 2 个参数是文件的输入输出方式(多个用“|”分隔),其说明参见后面的注释
// 如果既想写又想读就用 fstream
if (!infile)
{
// err
} // 移动文件内部位置指针。关于文件内部位置指针的操作函数请参见后面的注释
infile.seekg(sizeof(employee), ios::cur); for (int i = ; i < ; i++)
{
// 读取数据(要将地址转换为 char* 类型指针)
infile.read((char *)&r[i], sizeof(r[i]));
} infile.close();
} /*
* 文件的输入输出方式:
*
* ios::in - 以输入方式打开文件
* ios::out -以输出方式打开文件(这是默认方式),如果已有此名字的文件,则将其原有内容全部清除
* ios::app - 以输出方式打开文件,写入的数据添加在文件末尾
* ios::ate - 打开一个已有的文件,文件指针指向文件末尾
* ios::trunc - 打开一个文件,如果文件已存在,则删除其中全部数据,如文件不存在,则建立新文件。如已指定了 ios::out 方式,而未指定 ios::app, ios::ate, ios::in, 则同时默认此方式
* ios::binary - 以二进制方式打开一个文件,如不指定此方式则默认为 ASCII 方式
* ios::in | ios::out - 以输入和输出方式打开文件,文件可读可写
* ios::out | ios::binary - 以二进制方式打开一个输出文件
* ios::in | ios::binar - 以二进制方式打开一个输入文件
*/ /*
* 文件内部位置指针的操作函数:
*
* gcount() - 返回最后一次输入所读入的字节数
* tellg() - 返回输入文件指针的当前位置
* seekg(文件中的位置) - 将输入文件中指针移到指定的位置
* seekg(位移量, 参照位置) - 以参照位置为基础移动若干字节
* tellp() - 返回输出文件指针当前的位置
* seekp(文件中的位置) - 将输出文件中指针移到指定的位置
* seekp(位移量, 参照位置) - 以参照位置为基础移动若干字节
*
*
*
* 参照位置的说明:
* ios::beg - 文件开头(beg 是 begin 的缩写),这是默认值
* ios::cur - 指针当前的位置(cur 是 current 的缩写)
* ios::end - 文件末尾
*/

OK
[源码下载]