3

我正在使用 a逐字istringstream阅读。string但是,当我的条件失败时,我需要能够istringstream在读取前一个单词之前恢复到。我的示例代码有效,但我想知道是否有更直接的方法来使用流来完成此操作。

std::string str("my string");
std::istringstream iss(str);

std::ostringstream ossBackup << iss.rdbuf(); // Writes contents of buffer and in the process changes the buffer
std::string strBackup(ossBackup.str());      // Buffer has been saved as string

iss.str(strBackup);                          // Use string to restore iss's buffer
iss.clear();                                 // Clear error states
iss >> word;                                 // Now that I have a backup read the 1st word ("my" was read)

// Revert the `istringstream` to before the previous word was read.
iss.str(strBackup);                         // Restore iss to before last word was read
iss.clear();                                // Clear error states
iss >> word;                                // "my" was read again
4

2 回答 2

3

如果您愿意,可以使用tellg()seekg()来保存和恢复您的位置:

#include <string>
#include <sstream>

int main()
{
    std::istringstream iss("some text");

    std::string word;

    // save the position
    std::streampos pos = iss.tellg();

    // read a word
    if(iss >> word)
        std::cout << word << '\n';

    iss.clear(); // clear eof or other errors
    iss.seekg(pos); // move to saved position

    while(iss >> word)
        std::cout << word << '\n';

}
于 2014-10-06T19:03:34.947 回答
1

这实际上只保证适用于 stringstream,但您可以反复调用unget(),直到您达到空格字符:

#include <iostream>
#include <sstream>

template <int n>
std::istream& back(std::istream& is)
{
    bool state = is.good();

    auto& f = std::use_facet<std::ctype<char>>(is.getloc());
    for (int i = 0; i < n && is; ++i)
        while (is.unget() && !f.is(f.space, is.peek()));

    if (state && !is)
        is.clear();
    return is;
}

int main()
{
    std::stringstream iss("hello world");
    std::string str;

    std::cout << "Value Before: ";
    iss >> str;

    std::cout << str << std::endl;
    iss >> back<1>; // go back one word

    std::cout << "Value after: ";
    iss >> str;

    std::cout << str;
}

Live Demo

于 2014-10-06T18:38:19.067 回答