从字符串流中读取内容

时间:2015-05-12 07:01:40

标签: c++ stringstream

我正在测试如何从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吗?

1 个答案:

答案 0 :(得分:3)

实际上,readsome只会立即读取available characters ,这取决于平台,因此在流中仍有字符并且随后的调用可能会被允许返回0可能会返回丢失的字符。 要获取所有可用数据,我宁愿将readgcount结合使用,以获取您阅读的字符数。

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(),如果不是,那么这可能确实是编译器错误。