Valgrind快速使用

1.Valgrind 的核心组件(工具集)

  • memcheck 内存泄漏、内存错误检测(越界 / 野指针 / 双重释放)

  • cachegrind 缓存命中率,cpu性能分析

  • callgrind 函数调用关系、执行次数、耗时分析

  • helgrind 线程竞争、死锁检测

  • massif 堆内存使用趋势分析

其中mencheck是最常用的,也是本文讲解的

核心用法:

格式:

shell 复制代码
valgrind [通用参数] --tool=memcheck [memcheck参数] 程序名 [程序参数]

基础命令:

shell 复制代码
valgrind --tool=memcheck \
  --leak-check=full \       # 详细检测所有内存泄漏
  --show-leak-kinds=all \   # 显示所有泄漏类型(确定/间接/可能)
  --track-origins=yes \     # 定位内存越界/野指针的根源(精准但稍慢)
  --verbose \               # 输出额外调试信息
  --log-file=valgrind.log \ # 文本日志输出到文件
  --xml=yes \               # 启用 XML 格式输出
  --xml-file=valgrind.xml \ # XML 若使用xml日志输出到文件(必须补充!)
  ./test                    # 待检测的程序(可加参数,如 ./test 123

参数:

  • -- show-leak-kinds=all 显示 4 种泄漏类型:
    • definitely lost:明确泄漏(必须修复)
    • indirectly lost:间接泄漏(如容器内对象泄漏)
    • possibly lost:可能泄漏(需确认)
    • still reachable:内存未释放但可访问(如全局对象,可忽略)

几个例子快速熟悉使用:

1.new/new[] 与 delete/delete[]

new没有delete

c++ 复制代码
#include <iostream>
#include <string>
using namespace std;
void test_basic_leak() {
    int* num = new int(100);          // 分配堆内存
    std::string* str = new std::string("test leak"); // 分配堆内存
    
    {
    // 业务逻辑后直接返回,未释放指针
    /*  ....        */
        return ;
    }
    delete num; 
    delete str;
    num = nullptr ;
    str = nullptr ; 
}
int main(){
    test_basic_leak();
    return 0;
}
shell 复制代码
g++ -o test1 -g -O0 test.cc  # -g 可获取具体行号

new[] 而后 delete

c++ 复制代码
void test2(){
    int *arr = new int[10];
    /*
        ... ... 
    */
    delete arr;
}
shell 复制代码
 valgrind --leak-check=full --show-leak-kinds=all --log-file=v_2 ./test2

容器使用不当

c++ 复制代码
void test3(){
    vector<int*> arr(5) ;
    for(int i = 0 ; i < arr.size() ; ++i) {
        arr[i] = new int(i);
    } 
    arr.clear();
}
shell 复制代码
 valgrind --leak-check=full --show-leak-kinds=all --log-file=v_3 ./test3

类设计缺陷:

成员指针未释放
浅拷贝导致两次释放
c++ 复制代码
class MyClass{
public:
    MyClass(){
        buffer = new char[1024];
    }
    ~MyClass(){
        delete[] buffer;
    }
private:
    char *buffer ;
};
void test5(){
    MyClass obj1;
    MyClass obj2 = obj1 ;
} 
相关推荐
散峰而望5 小时前
【算法竞赛】C++函数详解:从定义、调用到高级用法
c语言·开发语言·数据结构·c++·算法·github
CoderCodingNo5 小时前
【GESP】C++五级真题(贪心思想考点) luogu-B4071 [GESP202412 五级] 武器强化
开发语言·c++·算法
我有一些感想……5 小时前
An abstract way to solve Luogu P1001
c++·算法·ai·洛谷·mlp
智者知已应修善业7 小时前
【求等差数列个数/无序获取最大最小次大次小】2024-3-8
c语言·c++·经验分享·笔记·算法
..过云雨7 小时前
17-2.【Linux系统编程】线程同步详解 - 条件变量的理解及应用
linux·c++·人工智能·后端
量子炒饭大师8 小时前
Cyber骇客的逻辑节点美学 ——【初阶数据结构与算法】二叉树
c语言·数据结构·c++·链表·排序算法
fpcc8 小时前
C++编程实践—false_type和true_type的实践应用
c++
量子炒饭大师8 小时前
Cyber骇客神经塔尖协议 ——【初阶数据结构与算法】堆
c语言·数据结构·c++·二叉树·github·
王老师青少年编程9 小时前
2025年12月GESP(C++二级): 环保能量球
c++·算法·gesp·csp·信奥赛·二级·环保能量球
CoderCodingNo9 小时前
【GESP】C++五级真题(贪心思想考点) luogu-P11960 [GESP202503 五级] 平均分配
开发语言·c++·算法