4

是否可以在std::ostringstream不使用std::ostringstream::str()成员函数创建std::string要搜索的情况下搜索 a 的内容?

我有以下内容,并希望避免std::string在每次调用时构造一个实例flush_()

#include <iostream>
using std::cout;

#include <ios>
using std::boolalpha;

#include <sstream>
using std::ostringstream;

#include <string>
using std::string;

class line_decorating_ostream
{
public:
    line_decorating_ostream()  { out_ << boolalpha;  }
    ~line_decorating_ostream() { cout << out_.str(); }

    template <typename T>
    line_decorating_ostream& operator<<(const T& a_t)
    {
        out_ << a_t;
        flush_();
        return *this;
    }

private:
    ostringstream out_;
    line_decorating_ostream(const line_decorating_ostream&);
    line_decorating_ostream& operator=(const line_decorating_ostream&);

    // Write any full lines.
    void flush_()
    {
        string s(out_.str());
        size_t pos = s.find('\n');
        if (string::npos != pos)
        {
            do
            {
                cout << "line: [" << s.substr(0, pos) << "]\n";
                s = s.substr(pos + 1);

            } while (string::npos != (pos = s.find('\n')));

            out_.clear();
            out_.str("");
            out_ << boolalpha << s;
        }
    }
};

int main()
{
    line_decorating_ostream logger;

    logger << "1 " << "2 " << 3 << " 4 " << 5 << "\n"
           << "6 7 8 9 10\n...\n" << true << "\n";

    return 0;
}

[这不会引起我担心的任何性能问题,只是好奇这是否可能。]

4

1 回答 1

4

使用它的streambuf类?还是自己写一个?(好的:你应该自己写一个:pbase并且pptr受到保护。)

class my_str_buffer : public basic_stringbuf<char>
{
  public:
    using basic_stringbuf<char>::pbase;
    using basic_stringbuf<char>::pptr;
};

my_str_buffer my_buf;
ostream str( &my_buf );
// do anything
string foo( str.rdbuf()->pbase(), str.rdbuf()->pptr() );

ostream构造函数stringbuf

于 2012-04-04T11:27:56.990 回答