Linux系統(tǒng)中怎么使用valgrind檢查內(nèi)存
發(fā)表時(shí)間:2023-08-10 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]在使用Linux系統(tǒng)編寫代碼過程中,有可能會(huì)發(fā)送內(nèi)存泄露的問題。所以用戶就應(yīng)該要學(xué)會(huì)檢查內(nèi)存,那么Linux如何檢查內(nèi)存呢?一般都是使用一些工具,本文就來介紹一下Linux系統(tǒng)中怎么使用valgri...
在使用Linux系統(tǒng)編寫代碼過程中,有可能會(huì)發(fā)送內(nèi)存泄露的問題。所以用戶就應(yīng)該要學(xué)會(huì)檢查內(nèi)存,那么Linux如何檢查內(nèi)存呢?一般都是使用一些工具,本文就來介紹一下Linux系統(tǒng)中怎么使用valgrind檢查內(nèi)存。
請(qǐng)看一下代碼:
#include 《stdlib.h》
#include 《stdio.h》
#include 《string.h》
static void mem_leak1(void)
{
char *p = malloc(1);
}
static void mem_leak2(void)
{
FILE *fp = fopen(“test.txt”, “w”);
}
static void mem_overrun1(void)
{
char *p = malloc(1);
*(short*)p = 2;
free(p);
}
static void mem_overrun2(void)
{
char array[5];
strcpy(array, “hello”);
}
static void mem_double_free(void)
{
char *p = malloc(1);
free(p);
free(p);
}
static void mem_use_wild_pointer(void)
{
char *p = (void*)0x80184800;
*p = 1;
}
static void mem_free_wild_pointer(void)
{
char *p;
free(p);
}
int main()
{
mem_leak1();
mem_leak2();
mem_overrun1();
mem_overrun2();
mem_double_free();
//mem_use_wild_pointer();
mem_free_wild_pointer();
return 0;
}
常見的內(nèi)存問題:
1. 動(dòng)態(tài)內(nèi)存泄露;
2. 資源泄露,這里以文件描述符為例;
3. 動(dòng)態(tài)內(nèi)存越界;
4.數(shù)組內(nèi)存越界;
5.動(dòng)態(tài)內(nèi)存double free;
6.使用野指針,即未初始化的指針;
7.釋放野指針,即未初始化的指針;
其中由于本示例代碼過于簡(jiǎn)單,第6中情況,使用野指針會(huì)直接導(dǎo)致crash,所以在main中,并沒有真正的調(diào)用那個(gè)示例代碼。由于 valgrind只能檢測(cè)執(zhí)行到的代碼,所以在后面的報(bào)告中,不會(huì)報(bào)告第6種錯(cuò)誤情況。但是,在大型的項(xiàng)目中,有可能使用野指針并不會(huì)導(dǎo)致程序 crash。另外上面的7中情況,有些情況嚴(yán)格的說,實(shí)際上可以歸為一類。
Linux是一套免費(fèi)使用和自由傳播的類Unix操作系統(tǒng)