我有一个Visual Studio 2008 C++项目,我在其中尝试将数据从多个类序列化到自定义std::streambuf
实现。
数据类及其序列化:
struct Header { /*...*/ };
inline std::ostream& operator<<( std::ostream& os, const Header& h )
{
/* serialize the members of Header here */
os.write( h.some_member, sizeof( h.some_member ) );
return os;
}
struct Info { /*...*/ };
inline std::ostream& operator<<( std::ostream& os, const Info& i )
{
/* serialize the members of Info here */
return os;
}
streambuffer实现提供了缓冲的I / O,并覆盖了
underflow
和overflow
。class MyStreamBuf : public std::streambuf
{
public:
MyStreamBuf() { InitBuffers(); };
private:
void InitBuffers()
{
recv_buffer_.resize( buff_size );
send_buffer_.resize( buff_size );
setg( &recv_buffer_[ 0 ], &recv_buffer_[ 0 ], &recv_buffer_[ 0 ] );
setp( &send_buffer_[ 0 ], &send_buffer_[ 0 ] );
};
enum { buff_size = 512 };
std::vector< char_type > recv_buffer_;
std::vector< char_type > send_buffer_;
int_type underflow() { /* ... */ };
int_type overflow( char_type c )
{
*pptr() = c;
pbump( 1 );
// if the buffer is full, flush the data
if( pptr() == epptr() )
flush();
return c;
};
void flush()
{
std::ptrdiff_t n = pptr() - pbase();
int written = /* send n bytes to the data destination */
pbump( -written );
};
}; // class MyStreamBuf
我的预期用法是这样的:
Header h( /* some useful info */ );
Info i( /* some useful info */ );
MyStreamBuf dest;
std::iostream my_stream( &dest );
dest << h << i; // MyStreambuf::overflow() is never called!
但是,从未调用
MyStreambuf::overflow
。我需要怎么做才能将数据保存到缓冲区?谢谢,
保罗·H
最佳答案
您需要在iostream上调用flush()
(或在streambuf上调用pubsync()
)。
传统上,您将在streambuf的析构函数中执行此操作(就像filebuf的析构函数调用close()
一样),在这种情况下,您只需要销毁它即可。
同样,提供从iostream继承的类也是常规的,该类拥有您的streambuf的实例,并确保在适当时刷新/销毁它。