Qt创建连接注意事项

Qt创建连接注意事项:

一、最好跟上Qt::UniqueConnection这个参数,作用是连接唯一,不会创建多余的连接,由其是在频繁创建连接时,会导致N个相同的连接都在起作用,进而导致逻辑性的内存泄漏。

如下代码:就使用了Qt::UniqueConnection来避免产生N个相同连接

cpp 复制代码
//创建串口
void SerialUpgradeModule::createSerialSlot()
{
    if (serial->isOpen()) {
        serial->close();
    }
    //移远模块优先连接,因为速度快。
    // 配置串口参数
    serial->clear();
    serial->setPortName("/dev/ttyACM2"); // 设置串口号,例如 "COM1" 或 "/dev/ttyACM2"
    serial->setBaudRate(QSerialPort::Baud115200); // 设置波特率
    serial->setDataBits(QSerialPort::Data8); // 设置数据位
    serial->setParity(QSerialPort::NoParity); // 设置校验位
    serial->setStopBits(QSerialPort::OneStop); // 设置停止位
    serial->setFlowControl(QSerialPort::NoFlowControl); // 设置流控

    if (serial->open(QIODevice::ReadWrite)) {
        qDebug() << "Serial port '/dev/ttyACM2' "<< "opened successfully.";

        // 成功打开后立即清空一次缓冲区,防止残留杂数据影响逻辑
        serial->clear();

        // 连接信号和槽,注意:接收文件包不能使用异步处理,只能使用同步处理
        connect(serial, &QSerialPort::readyRead, this, &SerialUpgradeModule::receiveAndHandleSerialDatagrams,Qt::UniqueConnection);
        connect(serial, QOverload<QSerialPort::SerialPortError>::of(&QSerialPort::errorOccurred), this, &SerialUpgradeModule::handleSerialError,Qt::UniqueConnection);
        connect(this, &SerialUpgradeModule::signal_processSerialData, this, &SerialUpgradeModule::slot_processSerialData,Qt::UniqueConnection);
        connect(this, &SerialUpgradeModule::signal_processSerialOnePieceProtocol, this, &SerialUpgradeModule::slot_processSerialOnePieceProtocol,Qt::UniqueConnection);
    } else {

        // 如果失败,开启重连定时器
        if (reconnectTimer && !reconnectTimer->isActive()) {
           reconnectTimer->start();
        }
        qDebug() << "Failed to open serial port '/dev/ttyACM2' "<< ":" << serial->errorString();
    }
}

秋风写于淄博,业务联系与技术交流:Q375172665

相关推荐
jiayou6432 分钟前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤21 小时前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区2 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1772 天前
《从零搭建NestJS项目》
数据库·typescript
何中应2 天前
Nginx转发请求错误
前端·后端·nginx
加号33 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏3 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐3 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
芝士雪豹只抽瑞克五3 天前
Nginx 高性能Web服务器笔记
服务器·nginx