我正在测试如何从std::streamstring
中读取数据,但我弄错了,有人能指出问题是什么吗?并给出正确的阅读方式?
我的测试代码是:
#include <iostream>
#include <string>
#include <sstream>
#define BUFFER_SIZE 16
int main(int argc, char ** argv)
{
std::stringstream ss;
ss << "Un texto con datos de ejemplo para probar la extacción de un stream";
std::cout << "Stream contents: '" << ss.str() << "'" << std::endl;
char buffer[BUFFER_SIZE] = {0};
std::streamsize read = 0;
do {
read = ss.readsome(buffer, BUFFER_SIZE - 1);
std::cout << "Read: " << ss.gcount() << std::endl;
std::cout << buffer << std::endl;
std::cout << "---" << std::endl;
std::fill(buffer, buffer + BUFFER_SIZE, 0);
} while ( read > 0 );
return 0;
}
我得到了输出:
Stream contents: 'Un texto con datos de ejemplo para probar la extacci¾n de un stream'
Read: 15
Un texto con da
---
Read: 15
tos de ejemplo
---
Read: 15
para probar la
---
Read: 15
extacci¾n de un
---
Read: 5
stre
---
Read: 0
---
正如您可能已经注意到,上次阅读操作只读取了5个字符而忽略了最后两个字母。即使它应该能够阅读它。我错过了somtehing吗?
答案 0 :(得分:3)
实际上,readsome
只会立即读取available characters ,这取决于平台,因此在流中仍有字符并且随后的调用可能会被允许返回0可能会返回丢失的字符。
要获取所有可用数据,我宁愿将read
与gcount
结合使用,以获取您阅读的字符数。
do {
ss.read(buffer, BUFFER_SIZE - 1);
read=ss.gcount();
std::cout << "Read: " << ss.gcount() << std::endl;
std::cout << buffer << std::endl;
std::cout << "---" << std::endl;
std::fill(buffer, buffer + BUFFER_SIZE, 0);
} while ( read > 0 );
只是为了澄清:
虽然我相信,你观察到的行为是标准所允许的,但我不明白为什么当输入流基于字符串文字(我不熟悉流的实现细节)时,实现应该表现得像这样。您可以检查的是,如果read
实际上对应于rdbuf()->in_avail()
,如果不是,那么这可能确实是编译器错误。