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

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

Win32開發中最易踏上的地雷

from:http://www.programfan.com/article/showarticle.asp?id=2776

  有關微軟編程技術的書籍可謂多如牛毛,但讀來讀去感覺還是MSDN比較權威。這里就拿一個例子來說吧,可能讓很多剛開始學習Win32 API程序設計、甚至是一些已經有一定Win32 API經驗的人感覺大汗淋漓。

  在學習Win32 API程序設計時,“第一課”我想都會學到“事件循環”吧?很多書給出了類似這樣的經典示例:

int WINAPI _tWinMain(HINSTANCE hInst, HINSTANCE hPrevInst, LPCTSTR lpCmdLine, int nCmdShow)
{
 MSG msg;
 
 
while(GetMessage(&msg, NULL, 00))
 
{
  TranslateMessage(
&msg);
  DispatchMessage(
&msg);
 }

 
 
return (int)msg.wParam;
}
 

  沒錯吧?多么熟悉的事件循環,它可以很好地工作,當收到一個WM_QUIT事件的時候,GetMessage()返回0,我們的程序得以正常退出。因此,幾乎任何一本講述Win32 API程序設計的書籍或文章,不論國內的還是國外的,都會以這樣一個程序作為第一章中的示例。

  然而,就在前不久,和往常一樣,閑來無事就翻起MSDN來,不知怎么的,就跑來看這個再熟悉不過的GetMessage()函數的參考來了。這一看不要緊,頭頂頓時冒出虛汗——原來這么多年我們這么寫程序,不能說是錯誤的,但絕對是有漏洞!來看MSDN上對于GetMessage()函數的講解(節選):

  注意:下面一段文字節選自MSDN Library Online,原文參見:

http://msdn.microsoft.com/
library/
en-us/
winui/
winui/
windowsuserinterface/
windowing/
messagesandmessagequeues/
messagesandmessagequeuesreference/
messagesandmessagequeuesfunctions/
getmessage.asp

>Return Value

>If the function retrieves a message other than WM_QUIT, the return value is nonzero.

>If the function retrieves the WM_QUIT message, the return value is zero.

>If there is an error, the return value is -1. For example, the function fails if hWnd is an invalid window handle or lpMsg is an invalid pointer. To get extended error information, call GetLastError.

>Warning
>Because the return value can be nonzero, zero, or -1, avoid code like this:

while (GetMessage( lpMsg, hWnd, 0, 0)) ...

>The possibility of a -1 return value means that such code can lead to fatal application errors. Instead, use code like this:

BOOL bRet;

while( (bRet = GetMessage( &msg, NULL, 00 )) != 0)

 
if (bRet == -1)
 
{
  
// handle the error and possibly exit
 }

 
else
 
{
  TranslateMessage(
&msg); 
  DispatchMessage(
&msg); 
 }

}
 

  草譯如下,希望更多的朋友能夠看清:

  返回值

   如果該函數收到一個除WM_QUIT之外的事件,其返回值為一個非零值。

   如果該函數收到一個WM_QUIT事件,其返回值為零。

   如果該函數發生錯誤,其返回值為-1。例如,如果hWnd是一個無效的窗口句柄,或者lpMsg是一個無效指針,該函數就會失敗。要獲得額外的錯誤信息,請調用GetLastError。

  警告

   由于該函數的返回值可能是非零的、零或者-1,請避免這樣做:

while (GetMessage( lpMsg, hWnd, 0, 0)) ...

   返回值-1出現的可能性意味著這樣的代碼會導致應用程序的致命錯誤。因此,我們應該編寫這樣的代碼:

BOOL bRet;

while( (bRet = GetMessage( &msg, NULL, 00 )) != 0)

 
if (bRet == -1)
 
{
  
// handle the error and possibly exit
 }

 
else
 
{
  TranslateMessage(
&msg); 
  DispatchMessage(
&msg); 
 }

}
 

  看到了嗎?我們這么長時間以來一直書寫的代碼,卻在這個“警告”中被“明令禁止”了!可能有的朋友會想,這樣的調用不可能出錯啊,我們通常都在啟動事件循環之前成功地創建了窗口,并且檢查了是否成功,因此傳遞給GetMessage()函數的窗口句柄肯定是有效的;而且,我們通常在堆棧上分配msg,并通過求址運算符(&)來計算它的地址并傳遞給GetMessage()函數,也不大可能出現無效指針啊?但是,還記得程序設計的基本原理之一嗎——永遠不要假設任何事情!因此,看來我們該把過去寫的代碼拿出來好好審視一遍了。

  這里僅提到了一個這樣被我們忽視的技術細節,我想一定還有很多、更多這樣的被忽視的東西存在!希望本文拋磚引玉,大家把你們發現的類似東西分享出來,讓大家都能夠寫出更加安全健壯的程序吧!

  P.S. 小感受一則,希望不要挨板磚……

  很多人都罵Windows是如何如何不安全,“緩沖區溢出”甚至變成連小學生都能隨口說出的“名詞”。其實,很多的Windows API都盡量保證了其執行的成功,并且以各種形式反饋給程序員,同時也在文檔中進行了詳細的描述。然而,又有多少人真正好好閱讀了這些講解?有多少技術作者、技術作家在下筆之前認真瀏覽了MSDN Library?

  Windows是安全的,不安全的是我們想當然的作風! 
本欄文章均來自于互聯網,版權歸原作者和各發布網站所有,本站收集這些文章僅供學習參考之用。任何人都不能將這些文章用于商業或者其他目的。( ProgramFan.Com )

posted on 2007-04-11 19:32 楊粼波 閱讀(237) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 久久中文字幕导航| 亚洲国产精品久久久久| 亚洲国产精品久久久久秋霞不卡| 美玉足脚交一区二区三区图片| 91久久极品少妇xxxxⅹ软件| 亚洲精选在线观看| 国产精品嫩草影院av蜜臀| 西西裸体人体做爰大胆久久久| 亚洲一区一卡| 在线看国产一区| 亚洲肉体裸体xxxx137| 国产精品国产福利国产秒拍 | 在线国产日韩| 91久久黄色| 国产精品亚洲аv天堂网| 久久精品五月婷婷| 欧美成人免费大片| 欧美在线精品一区| 欧美成人精品激情在线观看| 亚洲一二三区视频在线观看| 欧美资源在线| 在线一区二区三区四区| 欧美淫片网站| 亚洲一本视频| 老司机免费视频久久| 亚洲色图在线视频| 久久中文久久字幕| 亚洲欧美国产日韩天堂区| 久久综合色88| 久久成人精品一区二区三区| 免费欧美日韩国产三级电影| 久久国产88| 欧美体内she精视频在线观看| 久久夜色精品国产噜噜av| 欧美日韩情趣电影| 欧美大尺度在线| 国产日韩一区在线| 亚洲精品自在久久| 亚洲电影自拍| 欧美在线资源| 久久成人在线| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ入口 | 欧美成人中文| 免费欧美日韩国产三级电影| 国产精品入口福利| 亚洲六月丁香色婷婷综合久久| 在线成人激情黄色| 欧美有码视频| 久久国产免费看| 国产精品入口66mio| 亚洲精品资源| 中文欧美日韩| 欧美日韩国产一区| 亚洲毛片在线看| 亚洲免费观看高清完整版在线观看熊| 久久精品亚洲一区| 久久国内精品视频| 国产欧美午夜| 欧美一区二区三区视频免费播放 | 亚洲精品国产欧美| 久久只精品国产| 欧美成人午夜| 亚洲国产精品一区二区www| 久久国产精品久久久久久久久久 | 99亚洲一区二区| 欧美激情欧美狂野欧美精品| 亚洲国内自拍| 夜色激情一区二区| 欧美日韩一区二区在线观看| 99精品欧美一区二区蜜桃免费| 一区二区欧美在线观看| 欧美日韩亚洲高清| 亚洲图片在线观看| 欧美一区深夜视频| 国产一区二区精品在线观看| 久久成人人人人精品欧| 久久夜色精品| 日韩视频在线你懂得| 欧美日韩国产首页在线观看| 亚洲视频一区二区在线观看 | 亚洲人成在线观看一区二区| 欧美精品成人| 亚洲图片欧美日产| 久久亚洲一区二区| 99国产精品久久久久久久久久| 欧美日韩一区二区在线观看视频| 亚洲性夜色噜噜噜7777| 久久久久久精| 最新成人av网站| 国产精品久久久久77777| 亚洲尤物在线视频观看| 欧美成人一区二区三区| 一本色道久久综合亚洲精品小说 | 欧美电影在线观看完整版| 99在线精品视频在线观看| 久久成人一区| 99精品视频免费观看| 国产欧美精品一区二区色综合 | 久久久www成人免费精品| 亚洲国产人成综合网站| 午夜精品久久久久久久男人的天堂| 国产一区二区三区高清播放| 欧美激情精品久久久久久变态| 亚洲视频专区在线| 欧美激情91| 午夜视频久久久| 亚洲人成绝费网站色www| 国产精品毛片| 欧美激情免费在线| 久久久免费观看视频| 一区二区三区成人| 欧美激情1区2区3区| 久久成人免费日本黄色| 一区二区三区视频在线| 在线观看欧美日韩国产| 国产精品私人影院| 欧美片第一页| 免费看亚洲片| 久久精品国产99精品国产亚洲性色 | 午夜精品免费在线| 亚洲美女在线国产| 在线观看日韩一区| 国产视频亚洲| 国产精品swag| 欧美日韩一区二区三区四区五区| 美女主播一区| 久久婷婷人人澡人人喊人人爽 | 欧美α欧美αv大片| 久久精品国产99精品国产亚洲性色 | 亚洲欧洲综合| 在线精品福利| 18成人免费观看视频| 国语自产在线不卡| 国产日韩欧美三级| 国产区欧美区日韩区| 国产精品日日摸夜夜添夜夜av| 欧美日韩免费在线| 欧美涩涩视频| 欧美调教vk| 国产精品色婷婷| 国产精品你懂的在线欣赏| 国产精品久久一区二区三区| 国产精品盗摄久久久| 欧美视频精品在线| 国产精品qvod| 国产日韩欧美亚洲一区| 国产欧美精品一区aⅴ影院| 国产伦理一区| 国语自产精品视频在线看抢先版结局 | 在线观看91精品国产入口| 伊人久久婷婷| 亚洲精品乱码久久久久久按摩观| 亚洲国产精品va| 日韩视频免费大全中文字幕| 99re66热这里只有精品4| 一本色道久久综合狠狠躁篇的优点| 亚洲国产综合在线| 99这里有精品| 亚洲欧美国产三级| 久久久亚洲成人| 欧美国产视频在线观看| 亚洲欧洲美洲综合色网| 99ri日韩精品视频| 欧美一区二区在线| 美日韩精品视频| 国产精品国产a级| 黑丝一区二区三区| 亚洲伦理在线观看| 亚洲综合不卡| 裸体一区二区三区| 亚洲美女av黄| 欧美一级大片在线观看| 免费人成网站在线观看欧美高清| 欧美精品午夜| 精品二区视频| 亚洲女人天堂成人av在线| 六月婷婷久久| 一区二区三区导航| 另类酷文…触手系列精品集v1小说| 欧美日韩一级大片网址| 狠狠色丁香久久婷婷综合丁香| 一本一本a久久| 久久婷婷丁香| 亚洲特色特黄| 欧美成人中文| 极品尤物一区二区三区| 一区二区三区 在线观看视| 久久久蜜桃一区二区人| 99国产精品久久久久老师 | 中文av字幕一区| 裸体歌舞表演一区二区| 国产精品美女久久久久久免费| 亚洲精品123区| 久久嫩草精品久久久久| 中国成人黄色视屏| 欧美韩日精品|