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

相关推荐
kishu_iOS&AI10 分钟前
LLM —— Milvmus向量数据库
数据库·人工智能·milvus
名不经传的养虾人14 分钟前
从0到1:企业级AI项目迭代日记 Vol.46|三个检索源、缓存限流、深度整合——联网检索一日冲刺
数据库·人工智能·agent·ai编程·ai工作流·企业ai
luoyayun36114 分钟前
Qt + FFmpeg 实战:实现音频格式转换功能
qt·ffmpeg·音频格式转换
BugShare20 分钟前
Mac 上原生开发的开源免费、尽享丝滑数据库工具
数据库·macos·开源
Java爱好狂.20 分钟前
阿里1658页2026最新Java面试题总结(含答案)
数据库·redis·程序员·java面试·java面试题·java编程·java八股文
難釋懷27 分钟前
Nginx对上游服务器使用keepalive
服务器·nginx·github
jieyucx35 分钟前
《Go 数据库编程开篇:彻底打通 database/sql 与 MySQL 驱动的连接池调优密码》
数据库·sql·golang
白露与泡影39 分钟前
深入理解MySQL事务隔离级别:MVCC机制与Next-Key Lock如何解决幻读问题?
数据库·mysql
Gong-Yu39 分钟前
MySQL数据库运维——性能优化进阶2️⃣
运维·数据库·mysql·性能优化
吴声子夜歌42 分钟前
SQL经典实例——概述
数据库·sql