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

面對現實,超越自己
逆水行舟,不進則退
posts - 269,comments - 32,trackbacks - 0

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

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

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

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

 

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

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

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

要解決這個問題,首先要確定斷言發生的位置,如果是你自己設置的斷言被引發,就很好解決,如果是系統內部的函數產生的,那么一般是因為你傳入的函數參數無效引起。

2.內存相關:最簡單的非法訪問:

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

 

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

char *p = 0;

*p = 'a';

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

3.內存相關:不小心的棧上數組越界:

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

char str[3];

strcpy( str, "abc" );

就將看到如下的對話框:

 

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

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

char *str = new char [2];

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

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

以上代碼導致的錯誤對話框還要詭異些:

 

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

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

5.調用相關:函數調用約定帶來的錯誤:

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

 

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

調用約定是指調用一個函數時,函數參數的壓入順序、誰來清理棧的內容等。例如默認的C、C++調用約定__cdecl,對于函數的參數是從右往左壓入。而__stdcall(WIN API的調用約定)則是從左向右壓。我這里所說的函數類型不一樣,就是指一個函數是使用__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的,所以當通過函數指針my_func時,就導致了以上對話框的出現。但是當p指向show2時,又不會出錯,這是因為show2沒有參數,不同的調用約定不影響這個規則。

6.異常相關:默認終止程序

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

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

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

 

而如果不開調試器,則會得到:

 

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

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

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

int test_var;

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

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

 

8.破壞的堆

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

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

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



本文轉自:http://www.shnenglu.com/kevinlynx/archive/2008/04/24/47998.html

posted on 2012-09-14 14:18 王海光 閱讀(584) 評論(0)  編輯 收藏 引用 所屬分類: MFC
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美国内爽妇网| 欧美成人伊人久久综合网| 蜜桃av一区二区在线观看| 欧美一级成年大片在线观看| 亚洲欧美国产精品桃花| 亚洲深爱激情| 香蕉久久精品日日躁夜夜躁| 性18欧美另类| 久久久国产午夜精品| 久久伊人免费视频| 亚洲国产欧美精品| 亚洲国产精品女人久久久| 亚洲乱码国产乱码精品精可以看 | 日韩一级精品| 午夜精品视频在线观看一区二区| 先锋a资源在线看亚洲| 久久中文精品| 91久久精品www人人做人人爽| 亚洲国产成人久久综合| 国产精品久久久久久久久动漫| 欧美午夜精品久久久久久超碰| 国产精品永久免费观看| 亚洲福利免费| 午夜宅男久久久| 欧美激情亚洲综合一区| 亚洲一区美女视频在线观看免费| 久久激情久久| 欧美视频免费在线| 在线观看日韩国产| 午夜视频在线观看一区| 欧美国产综合一区二区| 亚洲欧美日韩成人| 欧美国产免费| 国产一区二区精品久久91| 99精品视频免费在线观看| 久久久综合免费视频| 日韩一级在线| 乱中年女人伦av一区二区| 国产精品视频| 亚洲天堂网在线观看| 欧美凹凸一区二区三区视频| 亚洲专区在线| 国产精品成人一区| 99精品国产热久久91蜜凸| 久久精品日产第一区二区三区| 99在线|亚洲一区二区| 久久在线视频| 一区二区三区在线免费观看| 性欧美办公室18xxxxhd| 99精品视频一区二区三区| 欧美大胆成人| 亚洲国产综合在线| 免费国产一区二区| 久久国产精品色婷婷| 国产免费成人在线视频| 亚洲欧美日韩一区二区三区在线| 亚洲精品少妇| 欧美日韩国产麻豆| 夜色激情一区二区| 亚洲精品一区在线| 欧美激情中文不卡| 免费不卡亚洲欧美| 亚洲第一中文字幕在线观看| 久久永久免费| 六月丁香综合| 亚洲日本成人女熟在线观看| 欧美大片免费观看| 免费在线观看日韩欧美| 亚洲精品欧洲精品| 日韩一本二本av| 国产精品剧情在线亚洲| 午夜精品福利在线| 香蕉亚洲视频| 欲香欲色天天天综合和网| 欧美高清在线播放| 欧美日韩国产欧| 性伦欧美刺激片在线观看| avtt综合网| 久久影院午夜片一区| 久久久久久成人| 亚洲国产美国国产综合一区二区| 欧美aa国产视频| 欧美寡妇偷汉性猛交| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 亚洲欧美日韩中文视频| 国产精品腿扒开做爽爽爽挤奶网站| 亚洲欧美一级二级三级| 亚洲一区国产| 在线欧美三区| 91久久极品少妇xxxxⅹ软件| 欧美亚州一区二区三区 | 久久综合99re88久久爱| 亚洲激情在线视频| 在线视频欧美一区| 国产精品一二三| 亚洲大胆av| 国产精品高清一区二区三区| 久久综合成人精品亚洲另类欧美 | 精品91在线| 亚洲欧洲在线一区| 日韩视频永久免费观看| 国产精品一区二区三区四区| 欧美大香线蕉线伊人久久国产精品| 欧美精品成人| 麻豆国产va免费精品高清在线| 欧美日韩视频一区二区三区| 久久天天综合| 国产精品视频导航| 亚洲人成网站精品片在线观看| 国产伦精品一区二区三区| 亚洲国产精品一区二区第四页av | 制服丝袜亚洲播放| 久久亚洲综合| 欧美亚洲日本网站| 欧美日韩亚洲国产一区| 欧美成人一品| 国产一区视频在线看| 一区二区日韩伦理片| 亚洲欧洲一区二区三区| 久久激情视频免费观看| 欧美在线视频免费观看| 欧美日韩视频在线| 亚洲第一黄网| 尤物yw午夜国产精品视频明星 | 亚洲国产福利在线| 黄色精品在线看| 新片速递亚洲合集欧美合集| 亚洲丝袜av一区| 亚洲精品国产精品乱码不99| 久久久久久久久蜜桃| 午夜一区二区三区不卡视频| 欧美精品导航| 欧美成人免费小视频| 狠狠狠色丁香婷婷综合激情| 欧美亚洲免费电影| 久久精品日韩| 黄网站色欧美视频| 久久免费精品视频| 欧美mv日韩mv国产网站| 在线免费观看视频一区| 久久天堂精品| 欧美激情视频给我| 亚洲免费观看高清完整版在线观看| 蜜臀久久99精品久久久画质超高清| 噜噜噜躁狠狠躁狠狠精品视频| 狠狠久久综合婷婷不卡| 久久久久久久精| 亚洲福利免费| 亚洲视频免费观看| 国产精品专区第二| 欧美一级在线播放| 韩国v欧美v日本v亚洲v| 欧美一区国产一区| 欧美成年人视频网站| 亚洲六月丁香色婷婷综合久久| 欧美另类在线播放| 亚洲一区二区视频| 麻豆av一区二区三区| 日韩午夜电影在线观看| 国产精品白丝av嫩草影院| 亚洲欧美日韩高清| 欧美黄色大片网站| 亚洲一区欧美一区| 国产欧美日韩高清| 久久伊伊香蕉| 亚洲精品日韩激情在线电影| 午夜精品久久久久久久99水蜜桃 | 久久精品国产精品亚洲| 狠狠色2019综合网| 欧美日韩免费观看一区=区三区| 亚洲性视频网址| 欧美电影免费| 午夜精品一区二区三区在线视| 伊人影院久久| 国产精品xnxxcom| 久久噜噜噜精品国产亚洲综合| 亚洲精品在线电影| 久久一区二区三区四区| 亚洲网友自拍| 亚洲国产精品一区制服丝袜 | 国产日韩精品入口| 欧美激情2020午夜免费观看| 午夜精品理论片| 亚洲国产三级在线| 久久在线精品| 午夜在线精品| 99视频一区| 亚洲国产福利在线| 国产日产欧产精品推荐色 | 亚洲精品国产无天堂网2021| 国产精品高潮呻吟| 亚洲欧洲美洲综合色网| 最新日韩精品| 亚洲欧美日韩精品一区二区| 一区二区三区在线免费视频| 欧美日韩在线大尺度| 久久精品最新地址| 亚洲中午字幕| 亚洲美女诱惑| 亚洲精品久久|