news 2026/6/15 15:25:37

Linux操作系统自带的测试内存泄漏的命令

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Linux操作系统自带的测试内存泄漏的命令

Linux操作系统自带的测试内存泄漏的命令:
watch -n 1 "ps -o vsz,rss,pmem,comm -ppidof DataBridgeDeamon
通过查看:rss的数据变化来粗略的判断是否有内存泄漏。

在嵌入式开发和 Qt 编程中,内存泄漏(Memory Leak)通常是指程序申请了内存但未能正确释放,导致可用内存持续减少。

结合你目前的 TCP 服务器项目,常见的内存泄漏原因可以归纳为以下几类:

1. 逻辑性堆积(最隐蔽的原因)

这是你之前遇到的情况。程序并没有“忘记”释放内存,而是数据产生的速度快于处理的速度,导致数据在内存中无限堆积。

  • 缓冲区积压:如m_receiveBuffer没能成功匹配到协议帧,导致数据只增不减。
  • 信号槽队列溢出:使用Qt::QueuedConnection时,如果发送信号频率极高,事件循环来不及处理,每个挂起的信号及其携带的参数(如巨大的QString)都会占用内存。

2. Qt 特有的对象生命周期问题

Qt 提供了QObject的父子树机制来自动管理内存,但如果不熟悉该机制,很容易出错:

  • 孤儿对象:通过new创建了QObject对象,但没有为其指定parent,且没有手动delete
  • 重复创建:在定时器或频繁触发的槽函数(如handleNewConnection)中new了对象,却忘记在关闭连接时调用deleteLater()

注意:在 Qt 中,建议对QTcpSocket使用socket->deleteLater()而不是delete socket,以防删除时还有未处理的事件导致崩溃。

3. 临时大对象的频繁拷贝

虽然这不一定是严格意义上的“泄漏”,但它会导致RSS (常驻内存)快速上升:

  • 字符串转换:在高频函数中使用QByteArray::toHex()QString::arg()拼接大字符串。这些临时对象在被垃圾回收前会占用大量内存空间。
  • 容器深拷贝:频繁地将大型QByteArrayQList作为信号参数进行值传递,而不是使用引用或常量引用。

4. 经典的 C++ 内存管理错误

这些是所有 C++ 程序员都会面临的基础问题:

  • 只申请不释放:调用了malloc/new但没有对应的free/delete
  • 异常退出导致的泄漏:程序在new之后、delete之前因为return或抛出异常而退出,跳过了释放逻辑。
  • 析构函数未定义为虚函数:当删除一个指向子类对象的基类指针时,如果基类析构函数不是virtual,子类的析构函数不会被调用。

5. 第三方库或系统层缓存

  • Glibc 内存碎片:有时候程序释放了内存,但操作系统的内存管理器(如glibc)并没有立刻将物理内存归还给内核,而是保留在自己的“内存池”中以备后用。这表现为 RSS 很高,但实际上并没有持续泄露。
  • 日志系统缓存:如果你向控制台或文件输出大量日志,系统可能会缓存这些 IO 操作,占用一定的内存。

总结

对于我现在的 TCP 项目,内存增长的前三大元凶通常是:

  1. 信号槽里的toHex字符串
  2. 未处理的数据在m_receiveBuffer中积压
  3. **频繁new出的QTcpSocket没有被正确deleteLater()**

建议建议:既然现在观察到 RSS 每 13 分钟增长约 0.5MB,建议运行 1 小时。如果 1 小时后它停留在 30-40MB 不动了,通常不需要担心;如果它一直涨到 100MB 以上,说明代码里肯定还有一个new出来的对象没有被管理起来。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 14:39:39

使用记事本编写运行Java程序,零基础小白到精通,收藏这篇就够了

一、编写Java源程序 Java 源程序可以使用任何一个文本编辑器来编写,这里以 Windows 下的记事本为例。 (1) 新建一个空白记事本,然后如实地输入下列内容。 很多初学者可能不明白此程序的全部意义,没关系,请完全按照实例的样式输入…

作者头像 李华
网站建设 2026/6/15 14:46:11

一文读懂_CTF:网络安全领域的_“实战练兵场”,新手入门全

收藏必备!CTF全解析:从定义到6大题型,小白程序员入门网络安全的实战指南 本文全面解析CTF(Capture The Flag)竞赛,介绍其作为网络安全实战训练的本质与价值。详细阐述CTF两种比赛形式(Jeopardy攻防答题赛和Attack-Defense攻防对抗…

作者头像 李华
网站建设 2026/6/15 15:19:12

零基础入门_CTF_全攻略:从靶场练手到赛事夺冠,附工具_

【强烈收藏】小白学CTF:网络安全实战学习路径与避坑指南 CTF是网络安全入门的最佳实战载体,适合零基础新手、在校学生和职场人。文章提供三阶段学习路径:基础搭建期(1-2个月)掌握Linux、Python和网络协议;…

作者头像 李华
网站建设 2026/6/15 12:23:45

灰盒测试在软件开发中的关键应用场景与价值探索

1 灰盒测试的核心定位与价值 灰盒测试作为介于黑盒测试与白盒测试之间的重要测试方法,既关注外部功能表现,又结合内部结构知识进行验证。其核心价值在于突破传统测试方法的局限:通过有限度的代码逻辑知晓(如API接口结构、数据库表…

作者头像 李华
网站建设 2026/6/15 14:37:09

保姆级教程:大模型学习指南(零基础入门到项目实战),建议收藏_AI大模型神仙级入门教程(非常详细)

这篇文章为AI大模型初学者提供全面入门指南,包括理解大模型基础、准备软硬件环境、学习机器学习与深度学习知识、使用预训练模型、进行模型微调以及参与实战项目。文章详细介绍了从初阶应用到模型训练再到商业闭环的学习路径,帮助读者系统掌握大模型技术…

作者头像 李华