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

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運(yùn)轉(zhuǎn),開心的工作
簡(jiǎn)單、開放、平等的公司文化;尊重個(gè)性、自由與個(gè)人價(jià)值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
使用PageHeap.EXE或GFlags.EXE檢查內(nèi)存越界錯(cuò)誤
2008年07月31日 星期四 19:35

我推薦使用PageHeap.Exe和Gflags.Exe,主要的原因還是因?yàn)楫?dāng)有人問內(nèi)存越界的錯(cuò)誤如何查出來的時(shí)候,國(guó)外的朋友經(jīng)常會(huì)推薦這兩個(gè)工具(highly recommend)。我用過之后,也覺得有些時(shí)候用用還是有好處的。

PageHeap.Exe將針對(duì)某個(gè)指定的應(yīng)用程序啟用Page Heap標(biāo)志,從而自動(dòng)監(jiān)視所有的malloc、new和heapAlloc的內(nèi)存分配,找出內(nèi)存錯(cuò)誤。

PageHeap.Exe的下載地點(diǎn):

http://download.microsoft.com/download/vc60pro/utility/6.0/win98/en-us/pageheap1.exe

下面我們簡(jiǎn)單地給出PageHeap使用步驟:

第一步:

在命令行中運(yùn)行PageHeap.Exe。如果你以前設(shè)置過啟用Global Page Heap標(biāo)志,那么你將看到一個(gè)列表,給出所有已經(jīng)啟用了的應(yīng)用程序的名字,不含路徑。

如下所示:

C:\>pageheap

pgh.exe????????????????????????????????? enabled

testSplit.exe??????????????????????????? enabled


第二步:

編譯一個(gè)小程序,其中有如下代碼:

void main()
{
int m_len = 5;
char *m_p = (char *)HeapAlloc (GetProcessHeap (),??? HEAP_ZERO_MEMORY, m_len);
m_p[m_len] = 0;
HeapFree (GetProcessHeap (),0, m_p);
}

Build出一個(gè)Debug版本。運(yùn)行之,你看不到有任何異常的報(bào)告。

但其實(shí)m_p[m_len]=0這句話就是越界寫了,因?yàn)橹环峙涞搅薽_p[m_len-1]!這種情況就叫Dynamic memory overrun。用BoundsChecker是可以查到的。

這時(shí),表面上看不出任何問題,但是一顆定時(shí)炸彈已經(jīng)埋下了。


第三步:

在命令行中運(yùn)行PageHeap /enable YourApplicationName.exe 0x01。

再運(yùn)行一次不帶參數(shù)的PageHeap,察看上面的命令是否生效。你的應(yīng)用程序應(yīng)該在啟用的列表中。

注意:千萬不要在YourApplication.Exe前面加上路徑!!

0x01的含義在后面說明。


第四步:

再次運(yùn)行你的程序。

你將會(huì)注意到在Output窗口的加載各種DLL之前,多了幾句話:

Loaded exports for 'C:\WINNT\System32\ntdll.dll'
Page heap: process 0x57C created heap @ 00130000 (00230000, flags 0x1)
Loaded 'C:\WINNT\system32\MFC42D.DLL', no matching symbolic information found.
..
Loaded 'C:\WINNT\system32\MSVCP60D.DLL', no matching symbolic information found.
Page heap: process 0x57C created heap @ 00470000 (00570000, flags 0x1)
Loaded exports for 'C:\WINNT\system32\imm32.dll'

這就是Page Heap的監(jiān)視機(jī)制在發(fā)揮作用!他告訴你你的堆00470000被創(chuàng)建出來了。

然后程序退出后,Output窗口有這么幾句話表明一定有什么錯(cuò)誤發(fā)生了:

Page heap: block @ 0015AFF8 is corrupted (reason 10)
Page heap: reason: corrupted suffix pattern
Page heap: process 0x57C destroyed heap @ 00471000 (00570000)
The thread 0x8A8 has exited with code 0 (0x0).

這說明在銷毀堆00470000時(shí)遇到了麻煩,就是數(shù)據(jù)塊0015AFF8被誤用了,原因是誤用了下標(biāo)語(yǔ)法。看,說得多么清楚!也節(jié)省了許多翻來覆去查代碼的工作!


PageHeap的使用中有幾點(diǎn)值得注意:

1:啟用PageHeap不能夠影響正在運(yùn)行中的應(yīng)用程序。如果你需要啟用一些正在運(yùn)行且不能重啟的程序的PageHeap,那請(qǐng)運(yùn)行PageHeap啟用后,重新啟動(dòng)機(jī)器。

2:要想查看PageHeap把信息放到哪里了,請(qǐng)打開你的注冊(cè)表,來到HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Image File Execution Options

你將會(huì)看到你的應(yīng)用程序也在這個(gè)項(xiàng)下面。你的應(yīng)用程序的GlobalFlag被設(shè)置為了0x02000000,PageHeapFlags被設(shè)置為了0x01。

3:PageHeap的原理是這樣,它在已分配的內(nèi)存的后面放上幾個(gè)守護(hù)字節(jié)(Guard Bytes),再跟上一個(gè)標(biāo)記為PAGE_NOACCESS的內(nèi)存頁(yè)。這樣,已分配內(nèi)存的后面如果被重寫了,那么守護(hù)字節(jié)就會(huì)被改變,于是當(dāng)內(nèi)存被釋放時(shí),PageHeap就會(huì)引發(fā)一個(gè)AV(Access Violation)。大體上就是這樣。所以只有最后釋放這塊問題內(nèi)存時(shí),才會(huì)有PageHeap的報(bào)告!這就是PageHeap的局限性吧。

參數(shù)0x01的含義:

FLAGS hex value (0x...) has the following structure:

??? B7-B0?? Bit flags??? 1 - enable page heap

??? 01 - enable page heap. If zero normal heap is used. In 99% of the cases you will want this to be set.
??? 02 - collect stack traces (default on checked builds)
??? 04 - minimize memory impact
??? 08 - minimize randomly(1)/based on size range(0)
??? 10 - catch backward overruns

看到了嗎?你還可以設(shè)置參數(shù)為0x10,從而可以檢查內(nèi)存向前的越界寫!

Gflags.Exe是微軟的Debugging Tools里面的工具。在Windows 2000的Resource Kit中也可以找得到。我們也可以用它來完成和PageHeap相同的任務(wù)。當(dāng)然,Gflags.EXE還能做許許多多其他的事情。這里我們就不介紹了,總之物超所值。

具體的使用辦法是:

1)???? 運(yùn)行Gflags.Exe;

2) 你將看到一個(gè)對(duì)話框。在”Image File”的編輯框中寫下你的應(yīng)用程序的名字,如YourApp.Exe。注意不要路徑!

3) 選擇”Image File Options”的單選鈕;

4) 這時(shí),你會(huì)看到對(duì)話框的內(nèi)容突然一變。選中“Place heap
allocations at ends of pages”前的復(fù)選框。

5) 點(diǎn)擊Apply按鈕。

這樣,就達(dá)到了PageHeap的效果。現(xiàn)在運(yùn)行你的程序,overwrite你的堆,就應(yīng)該生成一個(gè)AV了!


(請(qǐng)結(jié)合查看微軟KB:SAMPLE: PageHeap1.exe Finds Heap Corruption and Memory Errors (Q264471))

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久福利影视| 欧美在线观看一区二区| 欧美日韩亚洲一区二区三区在线观看 | 欧美国产精品v| 久久国产精品一区二区| 午夜视频一区二区| 亚洲一级二级| 亚洲一区二区三区免费观看| 亚洲免费一在线| 亚洲一区日韩在线| 亚洲精品乱码久久久久久| 日韩视频免费看| 日韩一区二区高清| 香蕉成人啪国产精品视频综合网| 一区二区三区免费看| 亚洲区第一页| 亚洲一区二区三区四区视频 | 欧美日本亚洲韩国国产| 免费观看成人网| 欧美日韩国产免费| 欧美视频1区| 欧美视频一区二区| 狠狠色狠狠色综合日日tαg| 韩国av一区二区三区四区| 国内成人自拍视频| 亚洲福利国产精品| 亚洲美女av网站| 欧美在线播放| 国产精品久久91| 国产精品久久久久久久久久久久久久| 亚洲一区二区三区四区五区午夜 | 欧美在线观看一二区| 欧美专区在线| 久久尤物电影视频在线观看| 欧美高清视频www夜色资源网| 亚洲片国产一区一级在线观看| 91久久精品国产91性色| 99视频在线精品国自产拍免费观看| 日韩一区二区精品| 久久久综合香蕉尹人综合网| 欧美r片在线| 国产精品免费福利| 亚洲毛片av| 亚洲欧美久久| 午夜久久福利| 亚洲福利视频网| 亚洲欧美国内爽妇网| 亚洲天堂av综合网| 久久一区二区三区国产精品| 欧美色欧美亚洲另类二区| 亚洲黄色一区二区三区| 欧美一区二区三区在线观看| 欧美高清在线一区| 久久激情五月丁香伊人| 欧美国产日韩亚洲一区| 国产欧美精品在线播放| 亚洲中字在线| 欧美大片免费| 99视频一区二区| 欧美精品一区二区三区四区 | 在线国产精品一区| 性做久久久久久久免费看| 亚洲美女毛片| 美女国内精品自产拍在线播放| 国产精品久久一级| 亚洲欧美视频在线观看| 亚洲国产精品一区| 久久久久久久久久码影片| 狠狠爱综合网| 久久国产主播| 亚洲精品一区二区三区四区高清| 免费日韩av片| 亚洲国产aⅴ天堂久久| 欧美大片免费观看在线观看网站推荐| 亚洲一区一卡| 国产精品久久久久一区二区三区共| 亚洲神马久久| 99精品国产在热久久婷婷| 国产午夜精品美女毛片视频| 亚洲午夜在线观看视频在线| 国产日韩欧美在线播放不卡| 在线成人激情黄色| 欧美成人一区二区三区| 99pao成人国产永久免费视频| 欧美日韩一区在线观看视频| 亚洲免费成人av电影| 亚洲国产日韩在线| 欧美日韩欧美一区二区| 久久精品伊人| 国产精品久久久久久久久久久久久久 | 午夜伦欧美伦电影理论片| 亚洲欧美日韩国产| 亚洲激情另类| 欧美在线免费| 亚洲一品av免费观看| 欧美黄色免费网站| 美女精品国产| 国产欧美一区二区精品婷婷| 可以看av的网站久久看| 在线视频亚洲欧美| 欧美成人a∨高清免费观看| 久久久久国产精品麻豆ai换脸| 欧美午夜电影一区| 在线午夜精品自拍| 亚洲人成网站999久久久综合| 午夜视频在线观看一区二区| 久久久国产午夜精品| 国产一区二区三区四区hd| 久久国内精品自在自线400部| 久久天天躁夜夜躁狠狠躁2022 | 久久一区二区三区国产精品| 欧美日本三区| 亚洲小视频在线观看| 亚洲一区二区在线视频| 国产亚洲第一区| 久久国产加勒比精品无码| 欧美在线首页| 1024日韩| 国产精品日韩二区| 99视频一区二区| 一区二区三区国产在线| 美女黄色成人网| 午夜国产精品视频免费体验区| 国产日韩欧美一二三区| 亚洲色无码播放| 国产精品videosex极品| 欧美福利专区| 欧美在线影院在线视频| 久久亚洲一区二区| 亚洲在线免费| 亚洲先锋成人| 国产精品福利在线| 欧美日韩不卡| 美女尤物久久精品| 欧美在线一二三| 亚洲欧美中文在线视频| 亚洲美女av电影| 亚洲精品在线一区二区| 一区二区电影免费在线观看| 国外精品视频| 亚洲视频综合| 一区二区福利| 夜夜嗨av一区二区三区免费区| 亚洲精品欧美日韩专区| 国语自产在线不卡| 国产一区二区日韩精品欧美精品| 亚洲香蕉网站| 亚洲综合丁香| 亚洲乱码精品一二三四区日韩在线| 亚洲午夜精品久久久久久浪潮| 夜夜爽99久久国产综合精品女不卡 | 老妇喷水一区二区三区| 亚洲视频图片小说| 亚洲午夜影视影院在线观看| 亚洲欧美日韩专区| 欧美一区二区三区在线视频| 国产综合精品一区| 在线观看视频一区二区欧美日韩| 国内在线观看一区二区三区| 国产美女一区二区| 99精品欧美一区| 久久狠狠婷婷| 亚洲精品女av网站| 亚洲二区视频在线| 亚洲国产高清一区二区三区| 亚洲视频第一页| 亚洲午夜在线| 你懂的国产精品永久在线| 欧美一区二区精美| 亚洲第一页自拍| 免费成人黄色片| 亚洲一区在线免费| 美女精品在线观看| 好吊一区二区三区| 久久精品国产96久久久香蕉| 欧美成人激情视频| 久久资源在线| 你懂的国产精品永久在线| 欧美精品手机在线| 一本色道久久综合精品竹菊| 久久久欧美精品| 性欧美超级视频| 很黄很黄激情成人| 国产女人精品视频| 亚洲免费av片| 国产欧美日韩精品一区| 欧美凹凸一区二区三区视频| 欧美高清视频在线观看| 亚洲福利专区| 欧美在线首页| 久久免费视频在线| 久久综合九色综合久99| 国产精品视频一| av成人手机在线| 在线视频精品一区| 欧美视频一区二区三区在线观看| 欧美成黄导航| 亚洲乱码国产乱码精品精天堂 | 久久久7777| 你懂的一区二区|