![](/img/trans.png)
[英]How to read and write correctly unsigned __int8 array to binary file using filestream in C++
[英]How to read/write unsigned array to ifstream/ostream in c++?
我有以下代码:
/*write to file*/
std::basic_ofstream<unsigned short> out(path, std::ios::out);
unsigned short *arr = new unsigned short[500];
for (int i = 0; i < 500; i++)
{
arr[i] = i;
}
out.write(arr, 500);
out.close();
/*read from file*/
unsigned short * data = new unsigned short[500];
std::basic_ifstream<unsigned short> rfile(path);
rfile.read(data, 500);
rfile.close();
只需将一个无符号的短数组写入文件,然后读取,但读取的值正确,直到数组中的索引25为止,之后的值为52685。
问题出在哪儿?
首先,不要使用非字符类型的basic_ofstream
模板参数(即char
, wchar_t
, char16_t
或char32_t
)。 在大多数情况下,只需使用ofstream
(以及ifstream
作为输入)。
您输入停止在第25个字符之后的事实实际上是您可能在Windows上的线索,其中ASCII字符26( 替换字符 )用于指示文本流的文件结尾。 但是,您尝试读取和写入二进制数据,因此需要使用二进制标志打开文件。
/*write to file*/
std::ofstream out(path, std::ios::binary);
unsigned short *arr = new unsigned short[500];
for (int i = 0; i < 500; i++) {
arr[i] = i;
}
out.write((char const*)arr, 500 * sizeof(arr[0]));
out.close();
/*read from file*/
unsigned short * data = new unsigned short[500];
std::ifstream rfile(path, std::ios::binary);
rfile.read((char*)data, 500 * sizeof(data[0]));
rfile.close();
同样有趣的是,十六进制的52685是0xCDCD。 这是Visual C ++(也许还有其他一些编译器)用来在调试模式下填充未初始化内存的值。 您的数组未从文件接收此值,这是分配内存时在其中插入的值。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.