Valgrind Memcheck 全解析教程:6個程序說明基礎內存錯誤

Valgrind 是一個強大的動態分析框架,其中的 memcheck 工具用于檢測 C/C++ 程序中類型不定的內存錯誤,是基礎級內存調試工具的重要選擇。

本文將通過 6 段有意義的錯誤代碼,全面講解 memcheck 的檢測原理和輸出分析,進而幫助學習者托底基礎。


一、memcheck 基本原理

Valgrind 使用一種動態代碼插裝技術(Dynamic Binary Instrumentation),保留所有內存分配/釋放/操作記錄,并對每一次訪問進行約束性檢查:

  • 訪問是否在合法范圍內
  • 訪問的內容是否已被初始化
  • 是否對釋放后的地址進行操作
  • 是否對非添配內存調用 free()

二、六種錯誤結構解析

在這里插入圖片描述

1. 堆內存超級讀取 + Use-After-Free

char *p = malloc(1);
*p = 'a';
char t = *(p + 1);     // 超級讀取
free(p);
*p = 3;               // 釋放后寫入

Valgrind 輸出

  • Invalid read of size 1 表示超級讀
  • Invalid write of size 1 表示 Use-After-Free

分析malloc(1) 只有一個 byte,訪問 p+1超范圍。 free(p) 后再寫 *p是釋放后操作,是精準級檢測值點。


2. 重復釋放 (Double Free)

char *p = malloc(1);
*p = 'a';
free(p);
free(p);

Valgrind 輸出

  • Invalid free() 指出上一次釋放地址

分析: 重復釋放將破壞 heap 內部結構,在 glibc 中可能導致 abort(),Valgrind 可精確抓出。


3. 非添配地址釋放 (Invalid Free)

char p = 'a';
free(p);

Valgrind 輸出

  • Invalid free() 指出試圖釋放的是 stack 地址

分析p 是一個普通變量,釋放非堆內存是第一級的編程錯誤,Valgrind 可相當精準地檢出。


4. 內存泄漏 (Memory Leak)

char *p = malloc(1);
*p = 'a';
// no free

Valgrind 輸出

  • definitely lost: 1 bytes in 1 blocks

分析: 程序退出時 heap 中存在未釋放內存塊,Valgrind 會標記泄漏類型,并可通過 --leak-check=full 查看分配地點。


5. 未初始化內存讀取 (Uninitialized Read)

char *p = malloc(1);
char t = *p;
printf("chat t = %c\n", t);
free(p);

Valgrind 輸出

  • Conditional jump or move depends on uninitialised value(s)

分析: malloc 分配的內存是隨機值,直接讀取而未初始化,會導致打印出的內容非確定,Valgrind 較好地檢測讀操作是否在可信區域內。


6. 釋放后讀取 (Use-After-Free: Read)

char *p = malloc(1);
*p = 'a';
free(p);
char t = *p;     // 釋放后讀
printf("chat t = %c\n", t);

Valgrind 輸出

  • Invalid read of size 1

分析: 釋放后內存地址成為無效,再讀取就是 Use-After-Free 錯誤,盡管訪問成功,結果也是未知行為。


結論

valgrind --tool=memcheck 是分析程序內存問題的重要工具:

  • 它能檢測 heap 區間的超級、未初始化、釋放錯誤;
  • 較難檢測 stack 超級或靜態區超級;
  • 通過精確輸出并配合 --track-origins=yes,可相當精精確確地保障基礎級 C 編程的內存健康。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/89882.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/89882.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/89882.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Vue3 實現 Excel 文件導入導出功能

在Vue 3中實現Excel文件的導入和導出功能,你可以使用一些流行的JavaScript庫,如SheetJS(也稱為xlsx)來處理Excel文件。以下是實現這一功能的基本步驟:1. 安裝SheetJS首先,你需要安裝xlsx庫。在你的Vue項目中…

CS231n-2017 Lecture2圖像分類筆記

圖像分類問題定義:在已有固定的分類標簽集合的前提下,能夠對輸入的圖像進行識別處理,從集合中找到該圖像所對應的標簽。對于計算機而言,圖像并非直觀的圖像,而是一個的像素集合,對于每個像素,其…

Typecho博客Ajax評論功能實現全攻略

文章目錄 Typecho實現Ajax評論功能的完整指南 引言 一、技術選型與準備工作 1.1 技術棧分析 1.2 環境準備 二、前端實現方案 2.1 基礎HTML結構 2.2 JavaScript處理邏輯 三、后端處理實現 3.1 創建插件處理Ajax請求 3.2 錯誤處理增強 四、安全性考慮 4.1 CSRF防護 4.2 輸入過濾 …

【計算機考研(408)- 數據結構】樹與二叉樹

樹與二叉樹 樹的定義及相關概念 樹是n(n≥0)個結點的有限集合,n 0時,稱為空樹,這是一種特殊情況。在任意一棵非空樹中應滿足: 1)有且僅有一個特定的稱為根的結點。 2)當n > 1時…

MacOS:如何利用終端來操作用戶

MacOS:如何利用終端來操作用戶MacOS:如何利用終端來操作用戶1. 創建用戶并賦予管理員權限步驟:2. 取消用戶的管理員權限解釋:3. 查看組成員查看 admin 組成員:查看 users 組成員:4. 其他常見的用戶管理命令…

基于SpringBoot+MyBatis+MySQL+VUE實現的醫療掛號管理系統(附源碼+數據庫+畢業論文+答辯PPT+項目部署視頻教程+項目所需軟件工具)

摘 要 在如今社會上,關于信息上面的處理,沒有任何一個企業或者個人會忽視,如何讓信息急速傳遞,并且歸檔儲存查詢,采用之前的紙張記錄模式已經不符合當前使用要求了。所以,對醫療掛號信息管理的提升&#x…

學成在線項目

黑馬程序員學成在線項目學習過程記錄 解決跨域問題

Shell腳本-grep工具

一、前言在 Linux/Unix 系統中,grep 是一個非常強大且常用的文本搜索工具,它可以幫助我們快速從文件或標準輸入中查找匹配特定模式的內容。無論是查看日志、調試腳本,還是進行自動化數據提取,grep 都扮演著至關重要的角色。本文將…

深入解析Ext2文件系統架構

要在硬盤上存儲文件,必須先將硬盤格式化為特定類型的文件系統。文件系統的主要功能就是組織和管硬盤中的文件。在Linux系統中,最常見的文件系統是Ext2系列,其早期版本為Ext2,后續又發展出Ext3和Ext4。雖然Ext3和Ext4對Ext2進行了功…

商業秘密保護:從法律理論到企業實戰

作者:邱戈龍、柯堅豪深圳商業秘密律師廣東長昊律師事務所在商業競爭中,商業秘密就像企業的"隱形護城河"。從法律角度看,它的保護路徑經歷了三次重要升級:從最初的"合同約定"到后來的"財產保護"&…

AI產品經理面試寶典第36天:AI+旅游以及行業痛點相關面試題的指導

一、AI如何解決旅游行業核心痛點? 面試官提問: "請結合具體案例說明AI在旅游行業的應用價值,以及它如何解決傳統旅游服務的痛點?" 你的回答: 以騰訊"一部手機游云南"為例,AI技術通過四大核心體系重構旅游體驗: 數字身份體系:通過人臉識別與用戶…

【conda】Linux系統中部署Conda環境

目錄 一、安裝 Miniconda 1.1 下載 Miniconda 安裝腳本 1.2 運行安裝腳本 1.3 初始化 Conda: 安裝完成后,初始化 Conda 環境 1.4 驗證安裝 二、設置虛擬環境默認存放路徑(可選) 三、conda創建虛擬環境 3.1 創建 Conda 環境…

Spring Boot 解決跨域問題

在 Spring Boot 中解決跨域問題(CORS)主要有三種常用方式,下面詳細說明每種實現方法: 方案一:全局配置(推薦) 在配置類中實現 WebMvcConfigurer 接口,統一配置所有接口的跨域規則&am…

Softhub軟件下載站實戰開發(十九):軟件信息展示

上一篇文章中我們上線了軟件分離展示&#xff0c;本篇文章我們聚焦軟件信息展示 軟件列表信息展示 點擊一級分類查詢該分類下所以軟件分類切換要有動畫效果分頁支持 核心實現 <transition-grouptag"div"class"software-grid"before-enter"before…

[HDLBits] Cs450/gshare

Branch direction predictor 分支方向預測器 A branch direction predictor generates taken/not-taken predictions of the direction of conditional branch instructions. It sits near the front of the processor pipeline, and is responsible for directing instructio…

[學習] 雙邊帶調制 (DSB) 與單邊帶調制 (SSB) 深度對比

雙邊帶調制 (DSB) 與單邊帶調制 (SSB) 深度對比 文章目錄雙邊帶調制 (DSB) 與單邊帶調制 (SSB) 深度對比**數學原理****調制表達式與頻譜****時域特性****頻域特性****Python 仿真代碼****仿真結果分析****工程應用建議**數學原理 設基帶信號為 m(t)m(t)m(t)&#xff08;帶寬為…

Gitee 提交信息的規范

在使用 git push 命令將代碼推送到 Gitee&#xff08;或任何 Git 平臺&#xff09;時&#xff0c;引號中的信息通常指的是 提交信息&#xff08;Commit Message&#xff09;。提交信息是對本次代碼修改的簡要描述&#xff0c;規范的提交信息有助于團隊協作和版本管理。 Gitee 提…

C 語言經典編程題實戰:從基礎算法到趣味問題全解析

在 C 語言學習過程中&#xff0c;通過實戰編程題鞏固知識點是非常有效的方式。本文整理了一系列經典 C 語言編程題&#xff0c;涵蓋基礎計算、邏輯判斷、圖形打印等多個維度&#xff0c;并附上完整代碼與解析&#xff0c;適合初學者參考學習上機題1.計算n以內所有正奇數的和 ?…

Chapter 3 Design of Switching Power Regulators

Chapter 3 Design of Switching Power Regulators Power Management Techniques for Integrated Circuit Design by Ke-Horng Chen 這本書比較深, 簡單介紹基本概念后, 就直接拋出大段公式和結論, 一章講其他書幾章內容, 適合有一定基礎, 想進一步做電源系統的人查閱. 優點是不…

算法題(176):three states

審題&#xff1a; 本題需要我們找到最佳鋪設道路&#xff0c;將三個國家聯通起來&#xff0c;然后輸出最佳鋪設道路的鋪設數量&#xff0c;若沒有聯通方法則輸出-1 思路&#xff1a; 首先我們正面思考&#xff1a;只需從某個點出發然后搜索到三個國家即可&#xff0c;最后對比所…