通过二进制的方式打开文件后,可以使用 r e a d read read 进行读取指定字节的数据流。
istream & read(char *buffer, int count);
这个函数第一个参数是一个 c h a r ∗ char * char∗,当我们读取一个结构体时,例如:
struct A
{
int b;
long c;
};
可以通过 C++ \text{C++} C++ 的 reinterpret_cast<new_type>(expression) \text{reinterpret\_cast<new\_type>(expression)} reinterpret_cast<new_type>(expression) 将 A 转换成 c h a r ∗ char * char∗,
A a;
ifstream file("file_path", ios::in | ios::binary);
file.read(reinterpret_cast<char *>(&a), sizeof(a));
这样便可以通过 a . b a.b a.b 的方式进行访问数据。
也可以定义一个字符串进行读取数据流,这样便省去了强制转换的需要,
int sz = 100;
char *buf = new char[sz];
file.read(buf, sz);
这里需要注意的是,由于是按照二进制读取的字节流,所以
b
u
f
buf
buf 里的东西直接打印出来可能和想象中的长度不一样,使用
s
t
r
l
e
n
strlen
strlen 函数获取的长度可能也不等于
s
z
sz
sz,这是由于读取的字节流里并不能避免终止符 \0
的存在,而
c
h
a
r
∗
char *
char∗ 是一个比较特殊的指针,当打印它的时候,会一直打印到终止符为止,
s
t
r
l
e
n
strlen
strlen 获取长度也是通过遍历到终止符来确定字符串的长度,所以在这里只有
s
z
sz
sz 能确定
b
u
f
buf
buf 的长度。虽然可能无法打印足够长的
b
u
f
buf
buf(可以一个一个字符打印),但是
b
u
f
buf
buf 里的数据并没有丢失,依然可以用来进行其他处理。