La taille de QByteArray est difficile à calculer ?
-
26-12-2019 - |
Question
Récemment, j'ai programmé pour effectuer la transmission de fichiers avec Qt.Je pensais que cela fonctionnait maintenant, je suis toujours curieux de savoir ce qui s'est passé.S'il vous plaît, aidez-moi à découvrir la raison.Merci beaucoup.
Pourquoi la taille de la tête est plus grande que la somme de sizeof(qin32), sizeof(qint32) et de la longueur du nom de fichier ? (Je suppose que c'est la raison de la fonction - setVersion())
QFileInfo info(file_to_send.fileName());
QByteArray head;
QDataStream out(&head, QIODevice::WriteOnly);
out.setVersion(QDataStream::Qt_5_0);
out << qint32(file_to_send.size() + info.fileName().length() + sizeof(qint32)*2)
<< qint32(info.fileName().length())
<< info.fileName();
tcpClient.write(head);
La solution
vous l'avez fait à compliquer.Le motif est comme ça:
QFileInfo info(file_to_send.fileName());
QByteArray head;
QDataStream out(&head, QIODevice::WriteOnly);
out.setVersion(QDataStream::Qt_5_0);
out << qint32(0)
<< info.fileName(); // << YouCanAddMoreStuffHere;
out.device()->seek(0);
out << qint32(out.length());
tcpClient.write(head);
et code de lecture:
void SomeClass::slotReadClient() { // slot connected to readyRead signal of QTcpSocket
QTcpSocket *tcpSocket = (QTcpSocket*)sender();
QDataStream clientReadStream(tcpSocket);
while(true) {
if (!next_block_size) {
if (tcpSocket->bytesAvailable() < sizeof(qint32)) { // are size data available
break;
}
clientReadStream >> next_block_size;
}
if (tcpSocket->bytesAvailable() < next_block_size) {
break;
}
QString fileName;
clientReadStream >> fileName; // >> YouCanAddMoreStuffHere; // same as above
next_block_size = 0;
}
}
Autres conseils
info.filename()
écrit sa propre longueur
si tu ne veux pas ça, tu peux le faire
QFileInfo info(file_to_send.fileName());
QByteArray head;
QDataStream out(&head, QIODevice::WriteOnly);
out.setVersion(QDataStream::Qt_5_0);
QByteArray filename = info.fileName().toLatin1();
out << qint32(file_to_send.size() + filename .length() + sizeof(qint32)*2);
<< qint32(filename .length())
out.writeRawData(fileName.constData(), filename.length());
tcpClient.write(head);
en utilisant writeRawData
qui contourne tout encodage intégré
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow