C++ 读取二进制文件

版权声明:听说这里让写版权声明~~~ https://blog.csdn.net/f_zyj/article/details/89437883

通过二进制的方式打开文件后,可以使用 r e a d read 进行读取指定字节的数据流。

istream & read(char *buffer, int count);

这个函数第一个参数是一个 c h a r char * ,当我们读取一个结构体时,例如:

struct A
{
	int b;
	long c;
};

可以通过 C++ \text{C++} reinterpret_cast<new_type>(expression) \text{reinterpret\_cast<new\_type>(expression)} 将 A 转换成 c h a r char *

A a;
ifstream file("file_path", ios::in | ios::binary);
file.read(reinterpret_cast<char *>(&a), sizeof(a)); 

这样便可以通过 a . b a.b 的方式进行访问数据。

也可以定义一个字符串进行读取数据流,这样便省去了强制转换的需要,

int sz = 100;
char *buf = new char[sz];
file.read(buf, sz);

这里需要注意的是,由于是按照二进制读取的字节流,所以 b u f buf 里的东西直接打印出来可能和想象中的长度不一样,使用 s t r l e n strlen 函数获取的长度可能也不等于 s z sz ,这是由于读取的字节流里并不能避免终止符 \0 的存在,而 c h a r char * 是一个比较特殊的指针,当打印它的时候,会一直打印到终止符为止, s t r l e n strlen 获取长度也是通过遍历到终止符来确定字符串的长度,所以在这里只有 s z sz 能确定 b u f buf 的长度。虽然可能无法打印足够长的 b u f buf (可以一个一个字符打印),但是 b u f buf 里的数据并没有丢失,依然可以用来进行其他处理。

猜你喜欢

转载自blog.csdn.net/f_zyj/article/details/89437883