QFile msnLogFile(item->data(Qt::UserRole).toString());
QDataStream logDataStream;
if(msnLogFile.exists()){
msnLogFile.open(QIODevice::ReadOnly);
logDataStream.setDevice(&msnLogFile);
QByteArray logBlock;
logDataStream >> logBlock;
}
此代码无效。结果的 QByte 是空的。如果我使用 char* 也是一样。奇怪的是,相同的代码可以在另一个程序中运行。我想找出两者之间的区别。如果我使用 int、uint、quint8 等,这会起作用
最佳答案
假设 msnLogFile 之前不是使用 QDataStream 创建的(如果是,则完全忽略此答案),您不想使用 >> 运算符。
原因是当QDataStream在写字符串的时候,它把字符串的长度放在输出字节的前面。这允许另一个 QDataStream 以正确的长度读回它并获得相同的结果。因此,为什么 int、qint8 等可以正常工作;没有预先设定的大小,它只是原始数据。
如果msnLogFile的内容是严格的文本,你需要传递QIODevice::Text打开和使用标志 QIODevice::readLine()或 QIODevice::readAll() ,但是,如果它是二进制数据,则必须使用 QDataStream::readRawData()并以正确的大小以正确的顺序读回数据。
关于c++ - QDataStream 和 QDataStream::operator>> ( char *& s ) 的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2693451/