青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

c++實例研究

從0開始

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  104 隨筆 :: 0 文章 :: 20 評論 :: 0 Trackbacks
在linux下使用用Valgrind查找內存泄漏和無效內存訪問(轉載)
來源: ChinaUnix博客  日期: 2007.03.09 23:44 (共有0條評論) 我要評論
 

用Valgrind查找內存泄漏和無效內存訪問
Valgrind是x86架構Linux上的多重用途代碼剖析和內存調試工具。你可以在它的環境中運行你的程序來監視內存的使用情況,比如C語言中的malloc和free或者C++中的new和delete。如果你使用了未初始化內存,在數組末端外設置內存或是忘記釋放指針,Valgrind都可以檢測出來。盡管Valgrind還可以做其它的工作,本教程仍然集中在如何使用它來發現內存相關錯誤,因為這也程序員經常出現的錯誤。
Windows用戶不必沮喪,雖然在Windows上沒有Valgrind可用,但是你可以試一試IBM的
Purify
,它在功能上和Valgrind相似。
獲得Valgrind如果你正使用Linux但卻沒有安裝Valgrind,可以去
這里
免費下載一份。
安裝過程非常簡單,只需要用bzip2解壓縮下載的軟件包并將其展開即可(下面例子中的XYZ是版本號)。
bzip2 -d valgrind-XYZ.tar.bz2
tar -xf valgrind-XYZ.tar
或者用更簡單的方法:
tar jxf valgrind-XYZ.tar.bz2
這會創建一個叫valgrind-XYZ的目錄,進入該目錄并運行
./configure
make
make install
好了,現在你已經安裝了Valgrind,可以開始了解如何用它了。
用Valgrind查找內存泄漏內存泄漏是最難發現的常見錯誤之一,因為除非用完內存或調用malloc失敗,否則都不會導致任何問題。實際上,使用像C或C++這類沒有垃圾回收機制的語言時,你一大半的時間都花費在處理如何正確釋放內存上。如果程序運行時間足夠長,一個小小的失誤也會對程序造成重大的影響。
Valgrind支持很多工具:Memcheck,Addrcheck,Cachegrind,Massif,Helgrind和Callgrind等。在運行Valgrind時,你必須指明想用的工具。在這篇教程中,我們主要集中在內存檢查工具上,它可以幫助我們檢查內存使用情況(呵呵,其它工具我也不會用)。如果沒有其它參數,Valgrind在程序結束后給出關于free和malloc總共調用次數的簡報:(注意,18490是進程號,你的機器上可能是其它值)
% valgrind --tool=memcheck program_name
...
=18515== malloc/free: in use at exit: 0 bytes in 0 blocks.
==18515== malloc/free: 1 allocs, 1 frees, 10 bytes allocated.
==18515== For a detailed leak analysis, rerun with: --leak-check=yes
如果程序中有內存泄漏的現象,內存分配的數量和內存釋放的數量會不一致(你不能使用一個free調用來釋放多個分配的內存)。
如果程序內存分配和釋放的數量不一致,你可以加上leak-check參數重新運行程序,這樣就可以看見分配了內存但卻沒有釋放的代碼。
為了演示這個功能,我寫了一個簡單的C程序并編譯生成"example1"應用。
#include
int main()
{
char *x = malloc(100); /* or, in C++, "char *x = new char[100] */
return 0;
}
% valgrind --tool=memcheck --leak-check=yes example1
在運行結果中,給出了調用malloc卻沒有調用free的函數列表。
==2116== 100 bytes in 1 blocks are definitely lost in loss record 1 of 1
==2116== at 0x1B900DD0: malloc (vg_replace_malloc.c:131)
==2116== by 0x804840F: main (in /home/cprogram/example1)
上面的結果并沒有告訴我們更多需要的信息,我們只知道在main函數中的malloc調用導致了內存泄漏,但并不知道是程序中的哪一行調用了malloc。這是因為我們在編譯程序時,沒有給gcc加上-g參數,相關的調試信息就丟失了。重編一次再運行,我們就得到了更多的信息(片斷)。
==2330== 100 bytes in 1 blocks are definitely lost in loss record 1 of 1
==2330== at 0x1B900DD0: malloc (vg_replace_malloc.c:131)
==2330== by 0x804840F: main (example1.c:5)
現在我們已經確切知道導致內存泄漏的是哪一行代碼了。盡管知道在哪里釋放內存仍然是一個問題,至少我們已經知道該從哪里入手。因為對每一次需要動態分配的內存,你都有一個何時分配,何時釋放的使用計劃,既然已經知道導致內存泄漏的分配點,也就基本理清了內存的使用計劃,有助于定位正確釋放內存的位置。
在加上--leak-check=yes參數后不再顯示內存泄漏錯誤前,你可能需要重復修改代碼很多次,一個優秀的,沒有內存泄漏的軟件就是這樣誕生的:-)。在運行Valgrind時加上--show-reachable=yes參數,可以找到每一個未來匹配的free或new,輸出結果和上面差不多,不過顯示了更多未釋放的內存。
用Valgrind查找無效指針使用用memcheck工具,Valgrind也可以找出無效堆內存使用。比如,如果你用malloc或new分配了一個數組,并訪問數組末端后面的內存:
char *x = malloc(10);
x[10] = ´a´;
Valgrind可以檢測出這個錯誤。用Valgrind運行下面的示例程序:example2
#include
int main()
{
char *x = malloc(10);
x[10] = ´a´;
return 0;
}
%valgrind --tool=memcheck --leak-check=yes example2
其結果是(片斷)
==9814== Invalid write of size 1
==9814== at 0x804841E: main (tst.c:6)
==9814== Address 0x1BA3607A is 0 bytes after a block of size 10 alloc´d
==9814== at 0x1B900DD0: malloc (vg_replace_malloc.c:131)
==9814== by 0x804840F: main (example2.c:5)
這個信息表明我們分配了10字節的內存,但是訪問了超出范圍的內存,因此,我們就進行了一個´非法寫´操作。如果試圖從那塊內存讀取數據,我們就會得到´Invalid read of size X´的警告(X是試圖讀取數據的大小,char是一個字節,而int根據系統的不同可能是2個字節或4個字節)。通常,Valgrind顯示出函數調用棧信息以方便我們準確定位錯誤。
檢測使用未初始化變量還有一類Valgrind可以檢測的操作是在條件判斷語句中使用未初始化變量。也許你應該養成在聲明變量時就進行初始化的習慣,不過Valgrind仍然可以幫助你找出使用未初始化變量的地方。比如,運行下面代碼生成的示例程序,example3
#include
int main()
{
int x;
if(x == 0)
{
printf("X is zero"); /* replace with cout and include
iostream for C++ */
}
return 0;
}
Valgrind會給出下面的結果(片斷)
==17943== Conditional jump or move depends on uninitialised value(s)
==17943== at 0x804840A: main (example3.c:6)
Valgrind甚至可以知道如果一個變量被賦予一個未初始化的變量,這個變量仍然處于"未初始化"狀態。比如運行下列代碼:
#include
int foo(int x)
{
if(x
Valgrind還能發現什么?Valgrind還能發現其它不正確使用內存的錯誤:如果你對同一塊內存釋放了兩次,Valgrind就會探測到,而你則得到非法free的調用棧信息。
Valgrind也能檢測到使用不正確方法釋放內存的錯誤。比如,在C++語言中有三種基本的內存釋放方法:free,delete和delete[]。free函數應該僅與malloc函數相對應--在一些系統上,你可能無須面對這個問題,但這樣不具備可移植性。delete[]應該又只能和new[](分配數組)相對應。(也許有些編譯器允許你不去理會這些規則,但不能保證所有的編譯器都允許你這樣做,畢竟它不是標準的一部分。)
如果程序中存在這些問題,你會得到下列錯誤信息:
Mismatched free() / delete / delete []
這些錯誤都應該被立刻修復,即使你的程序偶然能夠正常運行。
Valgrind不能查出哪些錯誤?Valgrind不對靜態數組(分配在棧上)進行邊界檢查。如果在程序中聲明了一個數組:
int main()
{
char x[10];
x[11] = ´a´;
}
Valgrind則不會警告你!出于測試目的,你可以把數組改為動態在堆上分配的數組,這樣就可能進行邊界檢查了。這個方法好像有點得不償失的感覺。
更多告誡使用Valgrind的負面影響是什么?它占用了更多的內存--可達兩倍于你程序的正常使用量。如果你用Valgrind來檢測使用大量內存的程序就會遇到問題,它可能會用很長的時間來運行測試。大多數情況下,這都不是問題,即使速度慢也僅是檢測時速度慢,如果你用Valgrind來檢測一個正常運行時速度就很慢的程序,這下問題就大了。
Valgrind不可能檢測出你在程序中犯下的所有錯誤--如果你不檢查緩沖區溢出,Valgrind也不會告訴你代碼寫了它不應該寫的內存。
總結Valgrind是x86架構上的工具,只能在Linux上運行(FreeBSD和NetBSD上的相關版本正在開發中)。它允許程序員在它的環境里測試程序以檢測未配對malloc調用錯誤和其它使用非法內存(未初始化內存)的錯誤以及非法內存操作(比如同一塊內存釋放兩次或調用不正確的析構函數)。Valgrind不檢查靜態分配數組的使用情況。
posted on 2006-04-03 17:05
加菲貓的簡單生活
閱讀(250)
評論(0)
  
編輯

收藏

引用

valgrind --tool=memcheck --leak-check=yes example1
所屬分類:
linux

測試經驗大家談
posted on 2010-06-10 15:35 elprup 閱讀(459) 評論(0)  編輯 收藏 引用 所屬分類: 工程問題集
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲欧美日韩国产中文在线| 欧美在线视频观看免费网站| 麻豆精品视频在线| 精品99视频| 欧美刺激午夜性久久久久久久| 久久国产精品黑丝| 亚洲成人在线视频网站| 亚洲第一狼人社区| 欧美理论视频| 亚洲性视频网站| 午夜精品久久久久久久99水蜜桃 | 欧美激情中文不卡| 一区二区三区三区在线| 亚洲视频一起| 狠狠色狠狠色综合系列| 欧美黑人在线观看| 欧美三级电影一区| 久久国产精品久久久久久久久久| 久久九九有精品国产23| 亚洲乱亚洲高清| 亚洲尤物在线| 亚洲人成精品久久久久| 一区二区三区黄色| 伊大人香蕉综合8在线视| 亚洲日本在线观看| 国产日韩欧美日韩| 亚洲国产婷婷香蕉久久久久久99| 欧美午夜精品理论片a级按摩| 欧美一区高清| 欧美激情影院| 久久一区二区三区四区| 欧美精品系列| 久久久久久久一区| 欧美视频中文在线看| 浪潮色综合久久天堂| 国产精品极品美女粉嫩高清在线| 久久夜精品va视频免费观看| 欧美亚洲成人免费| 欧美激情四色| 国产有码一区二区| 亚洲视频第一页| 亚洲久久成人| 久久久久久穴| 久久大综合网| 国产精品男女猛烈高潮激情| 亚洲国产天堂久久综合网| 黑人巨大精品欧美一区二区| 一区二区欧美日韩| 亚洲乱码国产乱码精品精天堂| 午夜精品久久久久| 亚洲欧美视频在线观看视频| 欧美国产亚洲另类动漫| 久久综合九色综合欧美狠狠| 国产日韩欧美二区| 亚洲午夜久久久久久久久电影院 | 国产一区二区精品久久| 在线视频中文亚洲| 一区二区三区成人精品| 欧美v亚洲v综合ⅴ国产v| 久久久久久**毛片大全| 国产欧美日韩精品专区| 亚洲视频你懂的| 亚洲伊人一本大道中文字幕| 欧美精品久久久久久久| 亚洲激情视频在线播放| 亚洲人精品午夜在线观看| 美女主播一区| 欧美国产一区二区在线观看| 亚洲国产成人在线播放| 美女网站久久| 亚洲国产天堂网精品网站| 亚洲国产一区二区三区高清 | 午夜亚洲激情| 久久精品网址| 一区二区在线观看视频在线观看| 久久激情视频久久| 久久夜色精品国产| 亚洲国产精品成人精品| 欧美高清在线观看| 亚洲美女毛片| 亚洲欧美日韩国产成人| 国产亚洲精品高潮| 久久亚洲综合| 亚洲精品一区二区网址| 亚洲制服欧美中文字幕中文字幕| 国产精品久久久久久久一区探花| 午夜久久久久久| 蜜臀av一级做a爰片久久| 亚洲人成免费| 国产精品捆绑调教| 欧美在线免费播放| 亚洲国产精品99久久久久久久久| 亚洲精品久久久一区二区三区| 欧美日本簧片| 欧美一区二区三区视频免费播放| 美女视频黄 久久| 一本色道久久加勒比88综合 | 久久乐国产精品| 亚洲啪啪91| 欧美伊人久久久久久午夜久久久久| 国内精品久久久久影院色| 欧美阿v一级看视频| 亚洲午夜在线观看视频在线| 久久久最新网址| 一区二区三区高清不卡| 韩国欧美一区| 欧美亚洲第一区| 久久综合给合| 亚洲女同性videos| 亚洲国产精品嫩草影院| 夜夜爽av福利精品导航| 国产精品毛片高清在线完整版| 欧美午夜精品理论片a级大开眼界| 亚洲黄一区二区三区| 亚洲国产清纯| 国产精品亚洲一区二区三区在线| 久久精品免费| 亚洲资源在线观看| 亚洲国产99| 久久久精品2019中文字幕神马| 一本色道久久综合亚洲二区三区| 国产日韩精品一区二区三区在线| 欧美电影在线| 久久久久久久久久久成人| 亚洲视频1区| 亚洲精品综合| 欧美电影在线观看完整版| 欧美一区二区三区婷婷月色 | 久久精品国产亚洲精品 | 久久久国产91| 亚洲欧美激情视频| 日韩午夜在线播放| 亚洲国产视频一区| 一色屋精品视频在线看| 狠狠v欧美v日韩v亚洲ⅴ| 国产精品亚洲аv天堂网| 欧美另类变人与禽xxxxx| 免费久久99精品国产自| 久久综合999| 麻豆91精品91久久久的内涵| 久久久久欧美| 久久久久久久网| 久久欧美肥婆一二区| 久久se精品一区二区| 欧美专区18| 久久久午夜电影| 美国成人直播| 欧美成人一区二区三区在线观看 | 久久都是精品| 在线观看三级视频欧美| 欧美国产一区二区三区激情无套| 欧美一区二视频在线免费观看| 最近看过的日韩成人| 欧美国产视频一区二区| 久久国产精品电影| 亚洲欧美国产一区二区三区| 亚洲免费黄色| 亚洲人成网站在线播| 99re成人精品视频| 亚洲日本在线视频观看| 亚洲高清不卡av| 国产精品卡一卡二| 国产亚洲免费的视频看| 国产精品永久在线| 国产欧美一级| 亚洲国产视频直播| 亚洲人永久免费| 亚洲精品中文字| 一本色道久久加勒比88综合| 亚洲欧美高清| 久久精品系列| 老牛嫩草一区二区三区日本 | 这里只有精品视频在线| 亚洲二区视频在线| 亚洲黑丝一区二区| 亚洲欧洲精品一区二区三区| 亚洲人线精品午夜| 亚洲你懂的在线视频| 羞羞漫画18久久大片| 久久不见久久见免费视频1| 久久精品国产亚洲a| 欧美日韩大片| 国产精品一区二区你懂得| 国产一区美女| 91久久久国产精品| 欧美亚洲午夜视频在线观看| 久久久精品国产免大香伊| 欧美大秀在线观看| 欧美丰满高潮xxxx喷水动漫| 亚洲图色在线| 久久久精品午夜少妇| 欧美精品色一区二区三区| 老妇喷水一区二区三区| 国产精品美女www爽爽爽| 合欧美一区二区三区| 99v久久综合狠狠综合久久| 亚洲字幕一区二区| 久久综合中文色婷婷| 亚洲精品一区二区三| 久久av一区二区三区亚洲|