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

相关推荐
有想法的py工程师21 小时前
PostgreSQL 分区表排序优化:Append Sort 优化为 Merge Append
大数据·数据库·postgresql
史迪仔011221 小时前
[QML] QML IMage图像处理
开发语言·前端·javascript·c++·qt
迷枫71221 小时前
达梦数据库的体系架构
数据库·oracle·架构
夜晚打字声1 天前
9(九)Jmeter如何连接数据库
数据库·jmeter·oracle
Chasing__Dreams1 天前
Mysql--基础知识点--95--为什么避免使用长事务
数据库·mysql
NineData1 天前
NineData 智能数据管理平台新功能发布|2026 年 3 月
数据库·oracle·架构·dba·ninedata·数据复制·数据迁移工具
小陈工1 天前
2026年4月7日技术资讯洞察:下一代数据库融合、AI基础设施竞赛与异步编程实战
开发语言·前端·数据库·人工智能·python
❀͜͡傀儡师1 天前
k8s部署的Nexus 3 数据库损坏恢复指南:从删除损坏数据库到完整数据重建
数据库·kubernetes·nexus3
StackNoOverflow1 天前
Spring Security权限控制框架详解
java·数据库·sql
不愿透露姓名的大鹏1 天前
Oracle归档日志爆满急救指南
linux·数据库·oracle·dba