USB串口操作(C,C++)

我们在日常使用过程中经常需要对USB串口进行一些读写操作,这里记录一下C,C++两种语言的操作过程.

注意:作者使用的环境为Ubuntu,在windows系统中使用需要对应把ttyUSB转换为COM口.

C语言读写USB串口

/* xiaochen open ttyUSB ------------------------------------------------------*/
int openttyUSB(char* path)
{
    int brate=9600,bsize=8,stopb=1;
    char *p,parity='N',dev[128],port[128],fctr[64]="";
    
    if ((p=strchr(path,':'))) {
        strncpy(port,path,p-path); port[p-path]='\0';
        sscanf(p,":%d:%d:%c:%d:%s",&brate,&bsize,&parity,&stopb,fctr);
    }
    else strcpy(port,path);
    
    sprintf(dev,"/dev/%s",port);
    int fd = open(dev, O_RDWR | O_NOCTTY);
    if (fd == -1) {
        perror("open");
        return 1;
    }
    struct termios ios={0};
    tcgetattr(fd,&ios);
    /*设置波特率*/
    cfsetospeed(&ios, brate);
    cfsetispeed(&ios, brate);

    /*设置数据位、停止位和校验位等*/
    ios.c_cflag &= ~PARENB; /*清除校验位*/
    ios.c_cflag &= ~CSTOPB; /*使用一位停止位*/
    ios.c_cflag &= ~CSIZE;  /*清除数据位*/
    ios.c_cflag |= CS8;   /*设置数据位为 8*/

    if (tcsetattr(fd, TCSANOW, &ios) != 0) {
        perror("tcsetattr");
        return 1;
    }
    tcflush(fd,TCIOFLUSH);

    /*printf("path: %s \n", path);*/

    return fd;
}

/*调用  path = 'ttyUSB0:115200:8:N:1:off'*/
int fd = openttyUSB(path);
/*读取数据*/
unsigned char read_buf[256];
m_read = read(fd, read_buf, sizeof(read_buf));

/*写出数据*/
int bytes_written = write(fd, buff, strlen(buff));
if (bytes_written == -1) {
    fprintf(stderr, "写入数据失败\n");
    close(fd);
    return 1;
}
    

C++读写USB串口

/*boost*/
#include<boost/asio.hpp>
#include<boost/bind.hpp>


boost::asio::io_service io;
boost::asio::serial_port sp(io, serial_port);
sp.set_option( boost::asio::serial_port::baud_rate(baud_rate));
sp.set_option( boost::asio::serial_port::flow_control( boost::asio::serial_port::flow_control::none ) );
sp.set_option( boost::asio::serial_port::parity( boost::asio::serial_port::parity::none ) );
sp.set_option( boost::asio::serial_port::stop_bits( boost::asio::serial_port::stop_bits::one ) );
sp.set_option( boost::asio::serial_port::character_size( 8 ) );

// 读取数据
char read_once[1]={'\0'};
boost::asio::read(sp,boost::asio::buffer(read_once));

// 写出数据
boost::asio::write(sp,boost::asio::buffer(buff,buff_len));

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: c语言中,通过USB串口接收数据时,有可能会出现乱码的情况。这种情况通常是由于数据传输的速率不统一、传输过程中某些数据丢失等原因造成的。 首先,如果数据传输的速率不统一,也就是接收端和发送端的速率不一致,那么接收端就会出现数据错位的情况。这样接收到的数据会变得混乱,成为乱码。 其次,在传输过程中,有可能会发生某些数据丢失。这种情况通常是由于芯片性能导致的。如果芯片的性能不够好,就会出现数据丢失,导致接收端收到的数据变成乱码。 最后,如果数据传输过程中存在干扰,也会导致接收端收到的数据变成乱码。但是这种情况相对比较罕见。 如果要解决乱码问题,可以尝试在代码中修改设置数据传输速率或者优化芯片性能,也可以采取别的措施,比如加入数据校验、增加缓存区大小等。只有在实际情况分析之后,才能采取最合适的解决方案。 ### 回答2: USB串口接收的数据乱码问题是普遍存在的问题。造成该问题的原因是多种多样的,主要包括以下几点。 首先,可能是物理连接出现了问题。USB串口的连接方式与传统串口不同,需要通过USB线连接电脑和设备。如果USB线质量差或者连接不稳定,就会出现乱码的现象。此时,可以更换高品质的USB线,或者确认连接是否牢固。 其次,可能是设备发送的数据格式不正确。串口通信需要约定好数据格式,包括波特率、数据位、停止位、奇偶校验等。如果设备与电脑间约定的格式不一致,收到的数据就会出现乱码。此时,可以查看设备的手册或者使用调试工具查看数据格式并进行修改。 另外,可能是电脑接收程序的问题。有时候,电脑的操作系统或者接收程序并不能正确地解读串口发送的数据。这时,可以考虑更换操作系统或者使用其他的串口接收程序。 最后,可能是设备发送的数据本身存在问题。例如设备发送的数据包含了特殊的字符或者数据帧结构不正确等。这种情况下,需要查找设备的手册,了解设备发送数据的相关规定,以及调试设备本身。 总之,USB串口接收的数据乱码问题需要从多方面进行排查和解决,才能最终找到问题的根源并进行解决。 ### 回答3: 在使用 USB 串口进行数据传输时,如果出现了乱码的情况,可能是以下几个原因导致的: 1. 波特率设置不正确 在使用 USB 串口进行数据传输时,需要正确设置波特率,否则可能会出现乱码的情况。波特率是指每秒钟传输的位数,如果设备 A 以 9600 bps 的速率传输数据,而设备 B 却以 115200 bps 的速率接收数据,就会导致设备 B 收到的数据出现乱码。 2. 数据位、停止位或校验位设置不正确 在使用 USB 串口进行数据传输时,还需要正确设置数据位、停止位和校验位的参数。如果设置不正确,数据传输时也会出现乱码的情况。 3. 电缆或接口质量不良 如果 USB 串口的电缆或接口质量不良,也可能导致数据传输时出现乱码的情况。建议更换质量较好的电缆或接口。 4. 设备驱动问题 USB 串口的驱动程序也可能会影响数据传输的稳定性。如果出现乱码的情况,可以尝试升级驱动程序或使用其他版本的驱动程序。 总之,在使用 USB 串口进行数据传输时,需要注意各种参数的设置,确保传输稳定,避免出现乱码的情况。如果仍然存在乱码,则需要进行深入的排查,找出问题所在,进行解决。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

晓晨的博客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值