C++读写二进制文件
2016-07-15 12:27
309 查看
转自:http://blog.csdn.net/lightlater/article/details/6364931
摘要:
使用C++读写二进制文件,在开发中操作的比较频繁,今天有幸找到一篇文章,遂进行了一些试验,并进行了部分的总结。
使用C++操作文件,是研发过程中比较频繁的,因此进行必要的总结和封装还是十分有用的。今天在网上找到一篇,遂进行了部分的试验,以记之,备后用。
本文读写文件均使用文件流进行操作,主要使用的类是ifstream, ofstream, 使用时,请务必包含文件fstream。如下:
#include <fstream>
写二进制文件
写二进制文件应该使用ofstream类,文件的打开模式一定要是 binary,如果传入的不是 binary, 文件将以ASCII方式打开。
下面是示例代码,用于写入文件。
std::ofstream fout("a.dat", std::ios::binary);
int nNum = 20;
std::string str("Hello, world");
fout.write((char*)&nNum, sizeof(int));
fout.write(str.c_str(), sizeof(char) * (str.size()));
fout.close();
而写文本文件则比较简单,如下:
std::ofstream fout("b.dat");
int nNum = 20;
std::string str("Hello, world");
fout << nNum << "," << str << std::endl;
fout.close();
读二进制文件
读取二进制文件可以使用ifstream 类来进行,文件的打开模式一定要是 binary,如果传入的不是 binary, 文件将以ASCII方式打开。
下面是示例代码:
std::ifstream fin("a.dat", std::ios::binary);
int nNum;
char szBuf[256] = {0};
fin.read((char*)&nNum, sizeof(int));
fin.read(szBuf, sizeof(char) * 256);
std::cout << "int = " << nNum << std::endl;
std::cout << "str = " << szBuf << std::endl;
fin.close();
而读取文本文件则比较简单:
std::ifstream fin("b.dat");
int nNum;
char szBuf[256] = {0};
fin >> nNum >> szBuf;
std::cout << "int = " << nNum << std::endl;
std::cout << "str = " << szBuf << std::endl;
fin.close();
文件的打开模式
文件操作时,如果不显示指定打开模式,文件流类将使用默认值。
在<fstream> 中定义了如下打开模式和文件属性:
ios::app // 从后面添加
ios::ate // 打开并找到文件尾
ios::binary // 二进制模式I/O(与文本模式相对)
ios::in // 只读打开
ios::out // 写打开
ios::trunc // 将文件截为 0 长度
可以使用位操作符 OR 组合这些标志,比如
ofstream logFile("log.dat", ios::binary | ios::app);
二进制文件的复制
这里我实现了一个二进制文件的复制操作,用于验证读写的正确性,示例代码如下:
<textarea cols="50" rows="15" name="code" class="cpp">bool copy_binary_file(const char * szDestFile, const char * szOrigFile) { if (szDestFile == NULL) { return false; } if (szOrigFile == NULL) { return false;
} bool bRet = true; std::ofstream fout(szDestFile, std::ios::binary | std::ios::app); std::ifstream fin(szOrigFile, std::ios::binary); if (fin.bad()) { bRet = false; } else { while(!fin.eof()) { char szBuf[256] = {0}; fin.read(szBuf, sizeof(char) * 256); if
(fout.bad()) { bRet = false; break; } // fout.write(szBuf, sizeof(char) * 256); } } fin.close(); fout.close(); return bRet; }</textarea>
后记
由于文本文件本质上也是磁盘上的一个个二进制编码,因此,读写二进制文件的代码同样可以读写文本文件,在文件类型不是很明确的读写操作中,直接使用二进制读写比较可取,如果可以直接判断文件类型,则可以分别对待。
关于读取文本文件,请参照http://blog.csdn.net/lightlater/archive/2011/04/15/6326338.aspx
摘要:
使用C++读写二进制文件,在开发中操作的比较频繁,今天有幸找到一篇文章,遂进行了一些试验,并进行了部分的总结。
使用C++操作文件,是研发过程中比较频繁的,因此进行必要的总结和封装还是十分有用的。今天在网上找到一篇,遂进行了部分的试验,以记之,备后用。
本文读写文件均使用文件流进行操作,主要使用的类是ifstream, ofstream, 使用时,请务必包含文件fstream。如下:
#include <fstream>
写二进制文件
写二进制文件应该使用ofstream类,文件的打开模式一定要是 binary,如果传入的不是 binary, 文件将以ASCII方式打开。
下面是示例代码,用于写入文件。
std::ofstream fout("a.dat", std::ios::binary);
int nNum = 20;
std::string str("Hello, world");
fout.write((char*)&nNum, sizeof(int));
fout.write(str.c_str(), sizeof(char) * (str.size()));
fout.close();
而写文本文件则比较简单,如下:
std::ofstream fout("b.dat");
int nNum = 20;
std::string str("Hello, world");
fout << nNum << "," << str << std::endl;
fout.close();
读二进制文件
读取二进制文件可以使用ifstream 类来进行,文件的打开模式一定要是 binary,如果传入的不是 binary, 文件将以ASCII方式打开。
下面是示例代码:
std::ifstream fin("a.dat", std::ios::binary);
int nNum;
char szBuf[256] = {0};
fin.read((char*)&nNum, sizeof(int));
fin.read(szBuf, sizeof(char) * 256);
std::cout << "int = " << nNum << std::endl;
std::cout << "str = " << szBuf << std::endl;
fin.close();
而读取文本文件则比较简单:
std::ifstream fin("b.dat");
int nNum;
char szBuf[256] = {0};
fin >> nNum >> szBuf;
std::cout << "int = " << nNum << std::endl;
std::cout << "str = " << szBuf << std::endl;
fin.close();
文件的打开模式
文件操作时,如果不显示指定打开模式,文件流类将使用默认值。
在<fstream> 中定义了如下打开模式和文件属性:
ios::app // 从后面添加
ios::ate // 打开并找到文件尾
ios::binary // 二进制模式I/O(与文本模式相对)
ios::in // 只读打开
ios::out // 写打开
ios::trunc // 将文件截为 0 长度
可以使用位操作符 OR 组合这些标志,比如
ofstream logFile("log.dat", ios::binary | ios::app);
二进制文件的复制
这里我实现了一个二进制文件的复制操作,用于验证读写的正确性,示例代码如下:
<textarea cols="50" rows="15" name="code" class="cpp">bool copy_binary_file(const char * szDestFile, const char * szOrigFile) { if (szDestFile == NULL) { return false; } if (szOrigFile == NULL) { return false;
} bool bRet = true; std::ofstream fout(szDestFile, std::ios::binary | std::ios::app); std::ifstream fin(szOrigFile, std::ios::binary); if (fin.bad()) { bRet = false; } else { while(!fin.eof()) { char szBuf[256] = {0}; fin.read(szBuf, sizeof(char) * 256); if
(fout.bad()) { bRet = false; break; } // fout.write(szBuf, sizeof(char) * 256); } } fin.close(); fout.close(); return bRet; }</textarea>
后记
由于文本文件本质上也是磁盘上的一个个二进制编码,因此,读写二进制文件的代码同样可以读写文本文件,在文件类型不是很明确的读写操作中,直接使用二进制读写比较可取,如果可以直接判断文件类型,则可以分别对待。
关于读取文本文件,请参照http://blog.csdn.net/lightlater/archive/2011/04/15/6326338.aspx
相关文章推荐
- C/C++编译和链接过程详解 (重定向表,导出符号表,未解决符号表)
- 从汇编角度看c++的const实现
- C++ 海康 YV12转RGB32,YV420转RGB32
- [C++]高效使用容器的一些建议
- C++小游戏——走迷宫
- C++将一串数字放到一个数组里随机排序
- C语言的第二次复习
- C++ STL set和multiset的使用
- Cpp环境【Uva1160】【Vijos2806】易爆物
- while语句
- USACO - 2.4.2 穿越栅栏(改编) 重庆一中高2018级竞赛班第二次测试 2016.7.13 Problem 3
- C++运算符重载
- 字节对齐小结
- USACO 2.4.2 穿越栅栏(原题) 解题报告
- 模拟生产环境使用thrift c++版
- A SQLite client library written in Modern C++
- c++构造函数详解
- C++ 实现 0-1 背包问题
- C++一些函数 备用 markdown
- [心得感想]16.7.14-21 DIARY