串口在Linux上进行第一对读写后挂起

时间:2014-05-22 13:27:01

标签: c++ linux serial-port boost-asio

我必须在我们实验室中与其中一个硬件进行串行通信。

使用bash,我可以写下我想要的时间并收到resposnes:

cat < /dev/ttyUSB0 &
echo 'SM?' >/dev/ttyUSB0
# SM=0480;
echo 'SMM=0475;' > /dev/ttyUSB0
echo 'SM?;' > /dev/ttyUSB0
# SM=0475;

我用asio编写一个简单的C ++应用程序,应该这样做。

#include <asio.hpp>
#include <asio/serial_port.hpp>
#include <thread>

int main(){
  asio::io_service service;
  asio::serial_port port(service,"/dev/ttyUSB0");
  port.set_option(asio::serial_port_base::baud_rate(9600));
  port.set_option(asio::serial_port_base::character_size(8));
  port.set_option(asio::serial_port_base::parity(asio::serial_port_base::parity::none));
  port.set_option(asio::serial_port_base::stop_bits(asio::serial_port_base::stop_bits::one));
  port.set_option(asio::serial_port_base::flow_control( asio::serial_port_base::flow_control::none));


  std::vector<char> ret(100);
  int len;
  asio::error_code ignored;
  asio::write(port,asio::buffer("SM?;"),asio::transfer_all(),ignored);
  len=port.read_some(asio::buffer(ret),ignored);
  std::cout.write(ret.data(),len);
  asio::write(port,asio::buffer("SSM=0480;"),asio::transfer_all(),ignored);
  asio::write(port,asio::buffer("SM?;"),asio::transfer_all(),ignored);
  len=port.read_some(asio::buffer(ret),ignored);
  std::cout.write(ret.data(),len);

  std::cout << std::endl;
  port.cancel();
  port.close();
  service.stop();
  service.reset();
  return 0;
}

但代码在第二次读取时挂起。我究竟做错了什么?

1 个答案:

答案 0 :(得分:0)

你没忘记缓冲区中的\ n吗?除非您使用echo

调用'\n',否则-n会在字符串中添加{{1}}字符

strace是调试此类问题的绝佳工具。