gpt4 book ai didi

c++ - 将数据序列化到 std::streambuf

转载 作者:塔克拉玛干 更新时间:2023-11-03 01:56:59 27 4
gpt4 key购买 nike

我有一个 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 并覆盖 underflowoverflow

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 的一个实例,并确保它在适当的时候被刷新/销毁。

关于c++ - 将数据序列化到 std::streambuf,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6835614/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com