提升流浪并写出奇怪的行为

Boost streambuf and write weird behaviour

本文关键字:      更新时间:2023-10-16

我正在使用streambuf作为串行端口通信的存储

io_service io;
serial_port sp(io);
sp.open("COM4");
sp.set_option( serial_port_base::baud_rate( 115200 ) );
sp.set_option( serial_port_base::character_size( 8 ) );
sp.set_option( serial_port_base::stop_bits( serial_port_base::stop_bits::one )  );
sp.set_option( serial_port_base::parity( serial_port_base::parity::none ) );
sp.set_option( serial_port_base::flow_control( serial_port_base::flow_control::none )   );
boost::asio::streambuf buffer;
// Fill buffer here
auto size = buffer.size();
std::cout << boost::format("Buffer size: %d") % size << std::endl;
boost::asio::write( sp, buffer );
size = buffer.size();
std::cout << boost::format("Buffer size: %d" ) % size << std::endl;

输出:

Buffer size: 8
Buffer size: 0

为什么方法size()返回不同的值?

boost::asio::write()运算消耗streambuf的输入序列,streambuf::size()返回输入序列的大小。

在这种特殊情况下,streambuf的输入序列在write()操作之前包含8个字节。 write()操作将一直阻塞,直到输入序列中的所有数据都已写入或发生错误。 write()操作成功,消耗输入序列中的 8 个字节,并返回一个值以指示已传输 8 个字节。 由于所有输入序列都已消耗,streambuf.size()返回 0。

有关 streambuf 用法的更多信息,请考虑阅读此答案。

相关文章:
  • 没有找到相关文章