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

相关推荐
这个DBA有点耶1 小时前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
镜舟科技2 小时前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend3 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence6 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
先吃饱再说1 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils1 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend1 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶1 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung1 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql
parade岁月1 天前
MySQL JOIN解析:朴实无华但食之有味
数据库·后端