我正在尝试将数据拆分成小数据包。我不确定这个读取方法是如何工作的,但是我给了一个512的缓冲区大小来读取文件。 但是我没有得到512,而是在我的第一个数据包中得到5。其他的从0到512不等(不应该发生)。
这是我试图拆分的zip文件: 在文本中,前几个字节看起来像这样
(de bucket like characters实际上是2个字符)
它似乎抓住前5个字节,但之后只是停止并转到下一个读取块。
因为它是512的缓冲区,所以前5个字节后的所有内容都是垃圾。 我正在使用ifstream。并且模式设置为二进制。
有什么建议吗?
void FileProcessor::send()
{
//If no file is opened return
if(!_file.is_open()) return;
//Reset position to beginning
_file.seekg(0, ios::beg);
//Result buffer
char * buffer;
char * partBytes = new char[_bufferSize];
//Read the file and send it over the network
while (_file.read(partBytes, _bufferSize))
{
buffer = Packet::create(Packet::FILE,partBytes);
Packet *p = Packet::create(buffer);
//cout << strlen(partBytes);
//p->PrintHex(buffer,_bufferSize+Packet::HeaderSize);
//break;
cout << "Normal size : \t" << strlen(partBytes)<< "\tPacketSize: \t" << p->getLength()<<"\n";
//cout << strcmp(p->getData().c_str(),partBytes) << "\n";
writeToFile(p->getData().c_str(),p->getData().length());
delete p;
}
//Write final bytes if any
if(_file.gcount())
{
//writeToFile(partBytes, _file.gcount());
buffer = Packet::create(Packet::FILE,partBytes);
Packet *p = Packet::create(buffer);
writeToFile(p->getData().c_str(),p->getData().length());
//cout << p->getLength() << "\n";
delete p;
}
//cout<< *p << "\n";
delete [] partBytes;
}
我现在正在测试直接读写。
答案 0 :(得分:0)
在你的循环中,不是假设它总是读取完整的数据缓冲区,而是使用gcount()
来查找它实际读取的数量,并传输那么多。
我觉得有必要补充一点:
buffer = Packet::create(Packet::FILE,partBytes);
Packet *p = Packet::create(buffer);
对我来说很奇怪。不确定是不是错了,但也不是很明显它也是正确的(如果它是正确的,设计似乎有点奇怪)。
我也会跳过动态分配和删除:
char * partBytes = new char[_bufferSize];
// ...
delete [] partBytes;
并改为使用std::vector<char>
。