我从文件中读取数据时遇到了一些问题 . 我希望能够读取wstring,以及任意大小的原始数据块(大小以字节为单位) .
std::wfstream stream(file.c_str());
std::wstring comType;
stream >> comType;
int comSize;
stream >> comSize;
char *comData = new char[comSize];
memset(comData, 0, comSize);
stream.read(comData, comSize);
//error C2664 : 'std::basic_istream<_Elem,_Traits>::read'
// : cannot convert parameter 1 from 'char *' to 'wchar_t *'
也许我正在使用错误的流,或类似的东西 . 基本上,我想读取一个wstring,跟随的数据大小(可以是任意数量的字节),然后是那么多字节的组件数据 . 显然,我无法读取char,因为模板假定为wchar_t .
我可以读取wchar_t,但是我必须确保数据存储为sizeof(wchar_t)对齐 . 否则,我最终可能会破坏流 . 一种情况是数据是15个字节 . 我必须读取16个字节,然后屏蔽不需要的字节,寻找流到15个字节的偏移量(如果可能,使用wchar_t模板化?)以便能够读取下一个数据块 .
显然,应该有一种更好的方式来实现我想要做的事情 .
3 回答
stream.read的问题在于它使用wchar_t作为wfstream的“字符单元” . 如果使用fstream,则使用char作为“字符单元” .
如果你想读宽字符,这将有效:
此外,15个字节的数据无法使用宽流读取,因为最小的单位至少为2字节(见下文),因此您只能读取sizwof(wchar_t)* n的块 .
但是如果你担心应用程序的可移植性,wfstream / wchar_t可能不是最好的解决方案,因为wchar_t没有标准的宽度(例如,在许多unix / linux系统上,windows wchar_t是16位,它是32位) .
将文本存储为宽字符的第二个问题是endianess,我建议使用UTF-8进行文本存储 .
考虑到您的要求,我认为wfstream不是最佳选择 . 考虑使用类似以下代码片段的内容 .
这输出:
我认为,_T(“filename.bin”)和tfstream是UI表达式;缓冲区和read()是DATA LOGIC表达式 . wfstream不能将缓冲区限制为wchar_t类型 . 用户界面不得与DATA LOGIC混合使用! wfstream在这里做错了