![](/img/trans.png)
[英]How to use boost::iostreams::null_sink as std::ostream
[英]How to use a compressor Boost::Iostreams filter as a sink in Boost::Log
我正在尝试使用boost::iostreams::gzip_compressor
来即时压缩使用Boost Log库创建的日志文件。 因此,当我调用BOOST_LOG()
,输出会即时压缩。 这是我到目前为止所尝试的:
#include <fstream>
#include <iostream>
#include <boost/iostreams/filtering_stream.hpp>
#include <boost/iostreams/filtering_streambuf.hpp>
#include <boost/iostreams/stream.hpp>
#include <boost/iostreams/filter/gzip.hpp>
#include <boost/smart_ptr/shared_ptr.hpp>
#include <boost/smart_ptr/make_shared_object.hpp>
#include <boost/log/core.hpp>
#include <boost/log/trivial.hpp>
#include <boost/log/sinks/sync_frontend.hpp>
#include <boost/log/sinks/text_ostream_backend.hpp>
#include <boost/log/sources/logger.hpp>
void init()
{
// Construct the sink
typedef boost::log::sinks::synchronous_sink< boost::log::sinks::text_ostream_backend > text_sink;
boost::shared_ptr< text_sink > sink = boost::make_shared< text_sink >();
boost::shared_ptr< std::ofstream > file = boost::make_shared< std::ofstream >(
"sample.gz", std::ios_base::out | std::ios_base::binary );
boost::iostreams::filtering_ostream out;
out.push( boost::iostreams::gzip_compressor() );
out.push( *(file.get()) );
for( int i = 0; i < 10; i++ ) {
out << "Hello world! " << i << std::endl; // compresses OK
}
sink->locked_backend()->add_stream( file );
// Register the sink in the logging core
boost::log::core::get()->add_sink( sink );
}
int main( )
{
init();
boost::log::sources::logger lg;
for( int i = 0; i < 10; i++ )
BOOST_LOG(lg) << "Bye world!" << std::endl; // Does not compress
return 0;
}
我觉得我应该以某种方式1)将整个filtering_ostream作为接收器,而不仅仅是file
或
2)以某种方式推记录器宿而不是file
中filtering_ostream
。
有人能指出我正确的方向吗? 谢谢!
我想你想要将filtering_ostream
作为记录器流传递。 你需要做两件事:
filtering_ostream
的shared_ptr
,和 您可以使用自定义shared_ptr
删除器来完成此操作。 deleter是一个传递给shared_ptr
构造函数的可选函数对象,将被调用以释放指针。 您可以将shared_ptr
存储到删除file
中的file
,以确保文件存在,只要该流存在。 在C ++ 11中,你可以使用这样的lambda:
boost::shared_ptr<boost::iostreams::filtering_ostream> out(
new boost::iostreams::filtering_ostream,
[file](std::ostream *os) { delete os; });
out->push(boost::iostreams::gzip_compressor());
out->push(*file);
sink->locked_backend()->add_stream(out);
lambda的[file]
部分将一个shared_ptr
保存到ofstream
直到调用了deleter。
如果你没有C ++ 11编译器,你可以用普通的仿函数做同样的事情,比如(未编译和未经测试):
struct MyDeleter {
boost::shared_ptr<std::ofstream> file_;
MyDeleter(const boost::shared_ptr<std::ofstream>& file)
: file_(file) {
}
void operator()(std::ostream *os) {
delete os;
}
};
...
boost::shared_ptr<boost::iostreams::filtering_ostream> out(
new boost::iostreams::filtering_ostream,
MyDeleter(file));
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.