有没有办法创建一个公共输出流对象在控制台和c ++文件中打印?

时间:2014-11-30 18:16:59

标签: c++ iostream fstream cout ofstream

我正在编写一个代码,我必须在控制台和文件上打印相同的数据。 有没有办法填充公共输出流对象,然后使用cout将其显示在控制台上,并使用fstream和iostream库将其导出到文件中?

1 个答案:

答案 0 :(得分:6)

不确定。您只需创建一个合适的流缓冲区,它可能存储在内部写入的其他流缓冲区中。使用此流缓冲区,然后创建您正在写入的std::ostream

例如,这是这种方法的简单实现:

#include <streambuf>
#include <ostream>

class teebuf
    : public std::streambuf
{
    std::streambuf* sb1_;
    std::streambuf* sb2_;

    int overflow(int c) {
        typedef std::streambuf::traits_type traits;
        bool rc(true);
        if (!traits::eq_int_type(traits::eof(), c)) {
            traits::eq_int_type(this->sb1_->sputc(c), traits::eof())
                && (rc = false);
            traits::eq_int_type(this->sb2_->sputc(c), traits::eof())
                && (rc = false);
        }
        return rc? traits::not_eof(c): traits::eof();
    }
    int sync() {
        bool rc(false);
        this->sb1_->pubsync() != -1 || (rc = false);
        this->sb2_->pubsync() != -1 || (rc = false);
        return rc? -1: 0;
    }
public:
    teebuf(std::streambuf* sb1, std::streambuf* sb2)
        : sb1_(sb1), sb2_(sb2) {
    }
};

class oteestream
    : private virtual teebuf
    , public std::ostream {
public:
    oteestream(std::ostream& out1, std::ostream& out2)
        : teebuf(out1.rdbuf(), out2.rdbuf())
        , std::ostream(this) {
        this->init(this);
    }
};

#include <fstream>
#include <iostream>

int main()
{
    std::ofstream fout("tee.txt");
    oteestream    tee(fout, std::cout);
    tee << "hello, world!\n";
}