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

loop_in_codes

低調(diào)做技術(shù)__歡迎移步我的獨立博客 codemaro.com 微博 kevinlynx

調(diào)試經(jīng)驗總結(jié)-VC下的錯誤對話框(陸續(xù)更新6.12.2008)

很早前就想寫點總結(jié)將編程中遇到的各種錯誤刨根挖底地羅列出來。但是因為這些錯誤(VC中開調(diào)試器遇到的各種錯誤對話框)都是隨機性的,真正想總結(jié)的時候又不想不起來有哪些錯誤。恰好最近運氣比較背,各種錯誤都被我遇遍了,于是恰好有機會做個總結(jié)。

這里所說的VC下的錯誤對話框時指在VC中開調(diào)試器運行程序時,IDE彈出的對話框。

1.不是錯誤的錯誤:斷言 .

將斷言視為錯誤其實有點可笑,但是因為有些同學(xué)甚至不知道這個,所以我稍微提一下。斷言對話框大致上類似于:

assert

斷言對話框是由assert引起的,在對話框上通常會給出表達式,例如assert( 0 ); 彈出對話框時就會將0這個表達式顯示出來(Expression:0)。關(guān)于assert的具體信息建議自己google。這里稍微提一下一個技巧:有時候為了讓assert提供更多的信息,我們可以這樣寫一個assert:

assert( expression && "Function : invalid argument!" );

因為字符串被用在布爾表達式中時,始終為true,不會妨礙對expression的判斷,當斷言發(fā)生時(expression為false) 時,斷言對話框上就會顯示這個字符串,從而方便我們調(diào)試。

要解決這個問題,首先要確定斷言發(fā)生的位置,如果是你自己設(shè)置的斷言被引發(fā),就很好解決,如果是系統(tǒng)內(nèi)部的函數(shù)產(chǎn)生的,那么一般是因為你傳入的函數(shù)參數(shù)無效引起。

 

2.內(nèi)存相關(guān):最簡單的非法訪問:

C、C++程序中經(jīng)常誤用無效的指針,從而大致各種各樣的非法內(nèi)存訪問(寫/讀)。最簡單的情況類似于:

wrongaccess

這樣的情況由類似以下代碼引起:

char *p = 0;

*p = 'a';

當你看到類似于“寫入位置XXXX時發(fā)生訪問沖突“時,那么你大致可以斷定,你的程序在某個地方訪問到非法內(nèi)存。開調(diào)試器對調(diào)用堆棧進行跟蹤即可找出錯誤。

 

3.內(nèi)存相關(guān):不小心的棧上數(shù)組越界:

當你寫下類似以下的代碼時:

char str[3];

strcpy( str, "abc" );

就將看到如下的對話框:

stackerror 

對話框大致的意思就是說str周圍的棧被破壞了,因為str本身就被放在棧上,所以strcpy(str,"abc")多寫入的'\0'就寫到非法的棧區(qū)域。看到這樣的對話框可以根據(jù)調(diào)用堆棧定位到錯誤發(fā)生的函數(shù),然后檢查此函數(shù)內(nèi)部定義的數(shù)組訪問,即可解決問題。

 

4.內(nèi)存相關(guān):不小心的堆上數(shù)組越界:
并不是每次數(shù)組越界都會得到上面所描述的錯誤,當數(shù)組是在堆上分配時,情況就變得隱秘得多:

char *str = new char [2];

strcpy( str, "ab" ); //執(zhí)行到這里時并不見得會崩潰

delete [] str;//但是到這里時就肯定會崩潰

以上代碼導(dǎo)致的錯誤對話框還要詭異些:

heaperror

似乎不同的DAMAGE對應(yīng)的錯誤號(這里是47)都不一樣,因為這里的錯誤發(fā)生在delete,而delete跟new很可能在不同的地方,所以這個錯誤調(diào)試起來不是那么容易,很多時候只能靠經(jīng)驗。

當看到類似的對話框時,根據(jù)調(diào)用堆棧跟到delete時,你就可以大致懷疑堆上數(shù)組越界。

 

5.調(diào)用相關(guān):函數(shù)調(diào)用約定帶來的錯誤:

這是所有我這里描述的錯誤中最詭異的一種,先看下對話框大致的樣子:

run_functioncall2

對話框大致的意思就是說(沒開調(diào)試器時對話框樣式可能不一樣),通過函數(shù)指針調(diào)用某個函數(shù)時,函數(shù)指針的類型(函數(shù)原型)可能與函數(shù)指針指向的函數(shù)的類型不一樣。這里的類型不一致主要是調(diào)用約定(call conversation)不一樣。如果函數(shù)類型(參數(shù)個數(shù),返回值)不一樣,一般不會出錯。

調(diào)用約定是指調(diào)用一個函數(shù)時,函數(shù)參數(shù)的壓入順序、誰來清理棧的內(nèi)容等。例如默認的C、C++調(diào)用約定__cdecl,對于函數(shù)的參數(shù)是從右往左壓入。而__stdcall(WIN API的調(diào)用約定)則是從左向右壓。我這里所說的函數(shù)類型不一樣,就是指一個函數(shù)是使用__cdecl,還是__stdcall。例如以下代碼:

 

#include <iostream> 

void __stdcall show( const char *str )

{

}
 

void __stdcall show2()

{

}
 

int main()

{

typedef
void (*Func)( const char *);

void *p = show;

Func my_func
= (Func) p;

my_func(
"kevin" );

return 0;

}
 

 

因為Func默認地被處理為__cdecl,而show是__stdcall的,所以當通過函數(shù)指針my_func時,就導(dǎo)致了以上對話框的出現(xiàn)。但是當p指向show2時,又不會出錯,這是因為show2沒有參數(shù),不同的調(diào)用約定不影響這個規(guī)則。

6.異常相關(guān):默認終止程序

當我們使用C++庫時,因為庫本身可能會拋出C++異常,如果你不捕獲這個異常,那么C++默認就會調(diào)用abort(或者exit)函數(shù)終止程序。例如:

 

void test()
{
   
throw std::exception( "some exceptions" );
}

 

當你調(diào)用test函數(shù)時,如果不catch這個異常,開調(diào)試器就會得到類似的錯誤對話框:

 

而如果不開調(diào)試器,則會得到:

 

當你看到類似于“This application has requested the Runtime to terminate it…”之類的字眼時,那就表明程序調(diào)用了abort(或exit)函數(shù),導(dǎo)致程序異常終止。其實這個錯誤只要開調(diào)試器,一般可以準確定位錯誤的發(fā)生點。

 

7.VC運行時檢查-未初始化變量

VC的調(diào)試器會對代碼進行運行時檢查,這可能會導(dǎo)致VC彈出對你看上去正確的代碼。這也許不是一個錯誤。例如:

int test_var;

if( test_var == -1 )
{
    test_var = 0;
}

test_var沒有初始化就進行if判斷,當運行以上代碼開調(diào)試器時,就會得到如下對話框:

withoutinit

8.破壞的堆

VC對于在堆上分配的內(nèi)存都做了記錄,我想這主要用于free釋放內(nèi)存時做歸還處理。

char *p = (char*) malloc( 100 );
p += 10;
free( p );

當執(zhí)行以上代碼時,因為p的值已經(jīng)改變,提交到free的指針值變化,VC就會給出以下錯誤提示:

bad_heap

posted on 2008-04-24 13:43 Kevin Lynx 閱讀(8235) 評論(9)  編輯 收藏 引用 所屬分類: c/c++通用編程

評論

# re: 調(diào)試經(jīng)驗總結(jié)-VC下的錯誤對話框 2008-04-24 17:19 王曉軒

很好,不過好多都沒有遇到過  回復(fù)  更多評論   

# re: 調(diào)試經(jīng)驗總結(jié)-VC下的錯誤對話框 2008-04-24 18:28 mm

全遭遇過了
不錯的總結(jié)  回復(fù)  更多評論   

# re: 調(diào)試經(jīng)驗總結(jié)-VC下的錯誤對話框 2008-04-25 11:38 夢在天涯

chao hao !

高手一個啊!  回復(fù)  更多評論   

# re: 調(diào)試經(jīng)驗總結(jié)-VC下的錯誤對話框 2008-04-26 22:28 yafare

調(diào)用相關(guān):函數(shù)調(diào)用約定帶來的錯誤

不一定是調(diào)用約定錯誤,數(shù)組訪問越界覆蓋掉vc設(shè)置的cookie,也可能是這樣的提示  回復(fù)  更多評論   

# re: 調(diào)試經(jīng)驗總結(jié)-VC下的錯誤對話框 2008-04-28 09:15 Kevin Lynx

@yafare
例如?舉個例子代碼看看?(從對話框給的內(nèi)容來看,似乎就是因為函數(shù)調(diào)用錯誤)  回復(fù)  更多評論   

# re: 調(diào)試經(jīng)驗總結(jié)-VC下的錯誤對話框 2008-04-28 22:00 草上飛

呵呵我剛才在Matlab中也出現(xiàn)了這樣的問題,想一想一小時前我還使用的好好的啊!仔細想想和操作系統(tǒng)相關(guān)的就是我把桌面主題給換了,隱約感覺到是這里的問題,于是我就把主題改為window XP,果然問題解決了,matlab可以正常啟動了!
  回復(fù)  更多評論   

# re: 調(diào)試經(jīng)驗總結(jié)-VC下的錯誤對話框 2008-04-29 22:22 李錦俊

這些都經(jīng)常遇到,還有一些很難遇到,更隱秘的錯誤才會導(dǎo)致的出錯對話框。  回復(fù)  更多評論   

# re: 調(diào)試經(jīng)驗總結(jié)-VC下的錯誤對話框(陸續(xù)更新5.5.2008) 2008-05-09 08:59 joke

頂  回復(fù)  更多評論   

# re: 調(diào)試經(jīng)驗總結(jié)-VC下的錯誤對話框(陸續(xù)更新6.12.2008) 2008-07-04 07:30 路緣

謝謝樓主分享,樓主真是有心人。  回復(fù)  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美中文日韩| 1024亚洲| 欧美凹凸一区二区三区视频| 久久国产福利| 久久久久国产一区二区三区| 欧美在线免费视频| 另类酷文…触手系列精品集v1小说| 久久久水蜜桃| 欧美精品日韩www.p站| 欧美精品一区二区在线播放| 欧美精品一区二区蜜臀亚洲| 国产精品久久国产三级国电话系列| 国产精品制服诱惑| 亚洲电影网站| 亚洲欧美综合国产精品一区| 久久黄金**| 亚洲福利视频一区二区| 99热精品在线| 久久久久综合网| 久久九九免费视频| 欧美在线视频免费播放| 免费在线欧美黄色| 一二三区精品| 蜜臀av国产精品久久久久| 欧美日韩在线播放一区| 国产视频精品免费播放| 亚洲人成人77777线观看| 欧美亚洲一区| 亚洲精品午夜| 羞羞视频在线观看欧美| 欧美理论在线播放| 激情六月综合| 久久国产精品亚洲77777| 亚洲精品视频在线| 玖玖精品视频| 国模私拍视频一区| 欧美一二三区精品| 一本色道久久| 欧美精品999| 亚洲国产另类久久精品| 久久精品视频在线播放| 亚洲一区二区视频在线| 蜜桃久久av一区| 亚洲第一精品电影| 久久免费的精品国产v∧| 亚洲视频1区2区| 欧美视频亚洲视频| 亚洲小说欧美另类社区| 亚洲国产精品一区二区www在线 | 亚洲大胆av| 久久嫩草精品久久久久| 亚洲午夜未删减在线观看| 免费成人高清| 亚洲黄色免费网站| 欧美成人一区二区三区片免费| 性做久久久久久免费观看欧美 | 久久久7777| 老司机精品视频网站| 亚洲伊人久久综合| 国产精品久久一卡二卡| 亚洲欧美日韩综合| 亚洲一区尤物| 国产欧美日韩精品丝袜高跟鞋 | 久久福利精品| 亚洲欧美文学| 国产在线一区二区三区四区 | 亚洲国产老妈| 久久国产精品99久久久久久老狼| 国产精品日本一区二区| 欧美一区二区国产| 午夜在线a亚洲v天堂网2018| 国产欧美日韩中文字幕在线| 香蕉久久夜色精品国产使用方法| 亚洲视频国产视频| 国产欧美日韩视频在线观看| 久久久欧美一区二区| 开元免费观看欧美电视剧网站| 伊人婷婷久久| 最新亚洲激情| 欧美色区777第一页| 欧美一区二区三区在线播放| 欧美亚洲在线视频| 女人香蕉久久**毛片精品| 亚洲精选久久| 亚洲精品在线三区| 国产精品一香蕉国产线看观看 | 久久激情视频免费观看| 久久九九全国免费精品观看| 亚洲人精品午夜| 亚洲综合二区| 亚洲精品中文字幕在线| 亚洲免费一级电影| 亚洲精品国产精品久久清纯直播| 一区二区三区日韩在线观看| 狠狠噜噜久久| 中日韩美女免费视频网站在线观看| 久久久精彩视频| 亚洲一区在线观看视频| 欧美专区日韩视频| 一区二区电影免费观看| 亚洲女女女同性video| 亚洲国产日韩欧美在线图片| 日韩午夜激情| 国产亚洲精品久久久久婷婷瑜伽| 亚洲激情一区| 国产精品看片你懂得| 欧美成人在线影院| 国产精品久久精品日日| 亚洲国产高清一区二区三区| 国产精品国产三级国产| 久久综合伊人77777麻豆| 亚洲一区二区三区四区五区黄 | 欧美人妖在线观看| 久久性天堂网| 国产老女人精品毛片久久| 91久久精品一区二区别| 黑人一区二区| 亚洲精品在线电影| 亚洲欧洲综合| 另类av导航| 免费一级欧美在线大片| 国产视频欧美视频| 中文日韩在线| 亚洲一区二区三区在线播放| 欧美成在线观看| 欧美国产一区二区| 亚洲高清资源综合久久精品| 久久国产福利| 久久久久青草大香线综合精品| 国产精品色一区二区三区| 一本久久综合亚洲鲁鲁| 亚洲视频精品| 欧美视频日韩视频| 亚洲色图自拍| 亚洲欧美国内爽妇网| 国产精品成人在线观看| 99热精品在线观看| 亚洲免费一在线| 国产精品高清在线观看| 中文亚洲视频在线| 欧美一二三区在线观看| 国产精品视频| 午夜亚洲激情| 久久蜜桃资源一区二区老牛| 国产精品欧美激情| 一区二区三区黄色| 亚洲欧美影音先锋| 国产一区在线免费观看| 久久久xxx| 亚洲国产精品一区二区久 | 香蕉国产精品偷在线观看不卡| 欧美视频在线观看视频极品| 欧美激情一区二区三区| 亚洲免费不卡| 国产精品久久一区二区三区| 99精品国产高清一区二区| 亚洲图片欧美日产| 国产麻豆精品视频| 久久精品国产亚洲一区二区| 久久久久88色偷偷免费| 国产欧美一区二区精品忘忧草| 午夜激情久久久| 欧美国产乱视频| 亚洲一区二区黄色| 黑人巨大精品欧美一区二区| 免费观看一区| 亚洲私人影吧| 狼人社综合社区| 99re8这里有精品热视频免费| 欧美日韩成人综合| 亚洲一区图片| 欧美成人午夜77777| 在线综合亚洲| 国产亚洲精品aa| 欧美不卡视频一区| 午夜精品短视频| 欧美不卡一卡二卡免费版| 亚洲另类在线视频| 国产伊人精品| 国产精品v欧美精品v日本精品动漫 | 国产亚洲aⅴaaaaaa毛片| 免费在线亚洲欧美| 亚洲欧美日韩第一区| 亚洲国产日韩在线一区模特| 欧美一区成人| 中文久久乱码一区二区| 精品电影一区| 国内精品视频666| 欧美成人乱码一区二区三区| 一区二区激情视频| 91久久精品国产91久久| 国产一区二区三区自拍| 国产精品www994| 欧美日韩精品国产| 欧美国产激情| 欧美成人中文| 欧美成人xxx| 久久天天综合| 久久久欧美精品| 久久久视频精品|