明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

Linux系統(tǒng)中怎么使用valgrind檢查內(nèi)存

[摘要]在使用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)存。

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)