青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
金慶的專欄
C++博客
::
首頁
::
新隨筆
::
聯系
::
聚合
::
管理
::
423 隨筆 :: 0 文章 :: 454 評論 :: 0 Trackbacks
公告
我的隨筆
我的評論
我參與的隨筆
留言簿
(12)
給我留言
查看公開留言
查看私人留言
隨筆分類
(502)
1. C/C++(166)
(rss)
2. 網游開發(108)
(rss)
3. Golang(20)
(rss)
4. Linux/Unix(30)
(rss)
5. 軟工與管理(44)
(rss)
6. Python(23)
(rss)
7. Erlang(18)
(rss)
8. Rust(16)
(rss)
9. 其它(77)
(rss)
隨筆檔案
(423)
2023年1月 (1)
2022年11月 (1)
2022年10月 (2)
2022年9月 (1)
2022年4月 (6)
2022年1月 (2)
2021年12月 (4)
2021年11月 (6)
2021年10月 (2)
2021年9月 (2)
2021年8月 (7)
2021年7月 (2)
2021年5月 (2)
2021年3月 (1)
2021年2月 (2)
2021年1月 (1)
2020年12月 (1)
2020年10月 (1)
2020年9月 (5)
2020年8月 (1)
2020年7月 (1)
2020年6月 (1)
2020年4月 (2)
2020年3月 (3)
2020年2月 (3)
2020年1月 (1)
2019年12月 (1)
2019年9月 (2)
2019年4月 (2)
2019年1月 (1)
2018年12月 (1)
2018年11月 (3)
2018年10月 (1)
2018年9月 (3)
2018年8月 (3)
2018年7月 (2)
2018年6月 (4)
2018年5月 (4)
2018年4月 (4)
2018年3月 (1)
2018年1月 (2)
2017年12月 (2)
2017年11月 (3)
2017年10月 (3)
2017年8月 (7)
2017年7月 (1)
2017年6月 (1)
2017年5月 (3)
2017年4月 (3)
2017年3月 (3)
2017年2月 (2)
2017年1月 (2)
2016年12月 (5)
2016年11月 (2)
2016年10月 (2)
2016年9月 (1)
2016年8月 (6)
2016年7月 (3)
2016年6月 (2)
2016年5月 (4)
2016年4月 (2)
2016年3月 (2)
2016年1月 (3)
2015年12月 (2)
2015年11月 (2)
2015年10月 (1)
2015年8月 (2)
2015年7月 (1)
2015年6月 (1)
2015年5月 (4)
2015年4月 (3)
2015年3月 (4)
2015年2月 (5)
2015年1月 (4)
2014年12月 (3)
2014年11月 (3)
2014年10月 (2)
2014年9月 (3)
2014年8月 (1)
2014年4月 (4)
2014年3月 (1)
2014年2月 (4)
2014年1月 (5)
2013年12月 (5)
2013年11月 (5)
2013年9月 (2)
2013年8月 (2)
2013年7月 (2)
2013年6月 (2)
2013年5月 (1)
2013年1月 (2)
2012年12月 (1)
2012年11月 (1)
2012年9月 (1)
2012年8月 (3)
2012年7月 (2)
2012年6月 (1)
2012年4月 (3)
2012年3月 (2)
2012年2月 (3)
2012年1月 (2)
2011年11月 (2)
2011年10月 (3)
2011年9月 (2)
2011年8月 (2)
2011年7月 (3)
2011年6月 (2)
2011年5月 (3)
2011年1月 (2)
2010年12月 (1)
2010年11月 (2)
2010年10月 (2)
2010年9月 (3)
2010年8月 (2)
2010年7月 (3)
2010年6月 (1)
2010年5月 (3)
2010年4月 (3)
2010年3月 (5)
2010年2月 (4)
2010年1月 (4)
2009年12月 (2)
2009年11月 (3)
2009年10月 (4)
2009年9月 (3)
2009年8月 (2)
2009年7月 (4)
2009年6月 (1)
2009年5月 (3)
2009年4月 (4)
2009年3月 (2)
2009年2月 (5)
2009年1月 (1)
2008年12月 (7)
2008年11月 (4)
2008年10月 (1)
2008年9月 (3)
2008年8月 (4)
2008年7月 (3)
2008年6月 (4)
2008年5月 (6)
2008年4月 (7)
2008年3月 (6)
2008年1月 (5)
2007年12月 (7)
2007年11月 (4)
2007年10月 (5)
2007年9月 (6)
2007年8月 (8)
2007年7月 (5)
相冊
公告照片
搜索
積分與排名
積分 - 665358
排名 - 24
最新評論
1.?re: boost::asio::spawn 將一統C++網絡庫
asio 成為C++首選網絡庫
--linda
2.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--金慶
3.?re: mingw編譯OrzNet
能發送一個mingw編譯好的OrzNet庫給我嗎? liuweiqcxy@163.com
謝謝!
--劉威
4.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--bigbad
5.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--bigbad
閱讀排行榜
1.?"multiple definition of" 錯誤(11085)
2.?SVN中邪惡的replace(11014)
3.?VS2005編譯libevent(10475)
4.?混音算法的學習與研究(10274)
5.?C調用lua腳本的效率測試(9030)
評論排行榜
1.?VC6正在被拋棄(35)
2.?VS2005編譯libevent(21)
3.?"multiple definition of" 錯誤(18)
4.?C++引用優于指針(17)
5.?ACE與ASIO之間關于Socket編程的比較(16)
需要判斷指針為空嗎
前幾天,KOK3客戶端因為我的資源配置錯誤而崩潰了。
調試器帶我到了出錯的代碼行,是一個空指針解引用。
代碼大致如下:
Item* pItem = itemList.getItem(index);
return *pItem;
getItem方法如下:
Item* ItemList::getItem(int index)
{
if (index < 0) return NULL;
if (index >= size()) return NULL;
return _list[index];
}
錯誤是因為資源加載出錯,列表為空,所以getItem()返回NULL.
對于資源加載出錯,應該加載時就提示出錯,不應該在使用時才報錯。
getItem()做了索引越界出錯處理,所以它的調用者必須檢查其返回值。
假設ItemList的指針元素保證不為空,正常情況下,索引正確情況下都不會返回空指針。
這種情況下,添加斷言是必要的。
Item* pItem = itemList.getItem(index);
assert(pItem);
return *pItem;
Item* ItemList::getItem(int index)
{
...
assert(_list[index]);
return _list[index];
}
對與索引值,還是用無符號數為好,可省去下界溢出斷。
posted on 2010-02-11 09:48
金慶
閱讀(4535)
評論(11)
編輯
收藏
引用
所屬分類:
1. C/C++
、
2. 網游開發
評論
#
re: 需要判斷指針為空嗎[未登錄]
2010-02-11 10:19
Bill Hsu
樓主是巨人的?
回復
更多評論
#
re: 需要判斷指針為空嗎[未登錄]
2010-02-11 10:49
kevin lynx
這個問題在我們組里也備受爭議。有人覺得對每個指針進行拿捏然后再決定判斷,很多余,所以索性對所有指針進行空判斷;有人覺得沒必要寫那么多冗余代碼,需要對每個指針進行上下文審查。
拿一個接口為例,接口實現里是否有必要對參數進行判斷?接口調用者是否需要對返回值做判斷?反正這種事情挺糾結的.
回復
更多評論
#
re: 需要判斷指針為空嗎
2010-02-11 11:19
Jimixu
簡簡單單的從兩個if不寫在一起,用||隔開就看出LZ功力非凡,可以節省很多不必要的判斷
Item* ItemList::getItem(int index)
{
if (index < 0) return NULL;
if (index >= size()) return NULL;
return _list[index];
}
回復
更多評論
#
re: 需要判斷指針為空嗎[未登錄]
2010-02-11 11:50
zz
@Jimixu
兩個if寫在一起用||隔開會增加很多判斷嗎?不解。
如果第一個條件成立,||的后一個條件不是不會判斷了嗎?
回復
更多評論
#
re: 需要判斷指針為空嗎
2010-02-11 11:58
jQuery
@Jimixu
=_=
回復
更多評論
#
re: 需要判斷指針為空嗎[未登錄]
2010-02-11 12:37
絕對零度
@Jimixu
有這種講解嗎?
回復
更多評論
#
re: 需要判斷指針為空嗎
2010-02-11 16:18
金慶
@kevin lynx
我的觀點是:只要有可能為空的,就一定要判斷是否為空; 不可能為空的,可以用一個assert斷言來表達。
關鍵在于判斷是否有可能為空。由函數調用者保證不為空的,就認為不可能為空,可在函數說明中注釋并在函數開始處加個斷言。由進程以外輸入決定的,如用戶輸入,文件輸入,或其他進程傳入數據決定的指針,即使外部接口規定了不會造成空指針,但仍應該對輸入判斷。外部輸入錯誤不應該造成程序錯誤。
回復
更多評論
#
re: 需要判斷指針為空嗎
2010-02-13 17:01
陳梓瀚(vczh)
理論上,對于一個對象A,如果他不能在這個上下文里面取到所有類型T的值,那么A的類型就不能是T。
舉個例子,句柄可以是個指針。但是如果有規定是不能為空,那就去搞個句柄類。無論你在哪里使用,都可以在復制和構造的時候集中檢查。譬如,句柄的構造函數可以檢查傳入的指針,為空就崩潰。只要構造成功了,那么句柄里面的內部指針肯定不會是空的。
回復
更多評論
#
re: 需要判斷指針為空嗎[未登錄]
2010-02-15 16:24
Steven
我是比較推崇這樣的寫法的
if (index < 0) return NULL;
if (index >= size()) return NULL;
雖然用 || 可以生成一樣的匯編代碼,但是對于調試維護來說是有區別的
如果我用 || 的話,并且在return 之前,輸出一些錯誤log
if (index < 0 || index >= size())
{
cout << "invalide index";
return null;
}
當我看到這個log的時候,你怎么才能知道到底是哪個判斷出錯了呢?index是太大還是太小呢?當然你可以說我應該把index的值也一并輸出出來,但是在實踐中很多判斷是很復雜的,很難輸出所有的值,比如長字符串的比較,總不能輸出那么多東西到log里吧。
回復
更多評論
#
re: 需要判斷指針為空嗎
2010-05-12 22:00
classyk
索引值用無符號數并不能減少判斷,反而更加麻煩
回復
更多評論
#
re: 需要判斷指針為空嗎
2010-05-13 09:38
金慶
@classyk
傳統的C程序中是int類型到處使用,而在C++中更傾向于各種功能用不同的類型,如容器大小用size_t. 用無符號數減少了小于0的判斷,“更加麻煩”在哪里?
回復
更多評論
刷新評論列表
只有注冊用戶
登錄
后才能發表評論。
相關文章:
How are dtLinks created in NavMesh
C++ parameter passing rules
Naming Conventions for Accessors
Visual Studio 2019 Compiler Hangs
Fbx File Format Identifier
查找內存錯誤
std::thread 中的異常會丟失調用棧
用賦值代替 protobuf CopyFrom()
vs2017 linux 編譯輸出改成 vs 格式
為 LiteIDE 添加選中標記
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 金慶
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
一个人看的www久久
|
国产精品夜夜夜一区二区三区尤
|
国产欧美一区二区色老头
|
亚洲一区二区三区精品动漫
|
亚洲美女黄色
|
欧美视频在线一区
|
午夜精品国产更新
|
性欧美超级视频
|
红桃av永久久久
|
欧美国产欧美亚洲国产日韩mv天天看完整
|
老司机久久99久久精品播放免费
|
亚洲国产你懂的
|
9l视频自拍蝌蚪9l视频成人
|
国产精品久久久久久久9999
|
久久国产欧美精品
|
久久亚洲高清
|
这里只有精品视频在线
|
亚洲伊人网站
|
亚洲国产精品一区二区久
|
亚洲电影成人
|
欧美午夜欧美
|
久久综合伊人77777
|
欧美紧缚bdsm在线视频
|
亚洲欧美日韩在线观看a三区
|
一本色道久久综合亚洲精品不卡
|
亚洲一级黄色av
|
午夜国产精品视频免费体验区
|
国产亚洲人成a一在线v站
|
欧美1级日本1级
|
欧美性猛交一区二区三区精品
|
欧美中文字幕第一页
|
老牛嫩草一区二区三区日本
|
亚洲在线网站
|
另类专区欧美制服同性
|
亚洲免费在线视频
|
欧美成年人在线观看
|
欧美一区日韩一区
|
欧美精品一区二区精品网
|
亚洲精选在线观看
|
亚洲欧美在线另类
|
99精品欧美一区二区蜜桃免费
|
性色av香蕉一区二区
|
一区二区欧美激情
|
久久综合久色欧美综合狠狠
|
午夜视频在线观看一区二区
|
欧美极品一区
|
欧美激情1区2区
|
狠狠色香婷婷久久亚洲精品
|
中文精品在线
|
一区二区三区精品
|
牛牛影视久久网
|
久久综合给合久久狠狠狠97色69
|
国产精品欧美日韩一区二区
|
亚洲精品一区二区三
|
亚洲丰满少妇videoshd
|
性久久久久久久久久久久
|
亚洲图中文字幕
|
欧美一区二区三区视频在线观看
|
中文有码久久
|
老司机午夜精品
|
欧美中文字幕不卡
|
欧美四级电影网站
|
亚洲综合第一页
|
欧美—级高清免费播放
|
久久综合伊人
|
国内精品久久久久伊人av
|
午夜视频一区二区
|
久久精品成人一区二区三区
|
国产精品欧美一区喷水
|
久久深夜福利
|
国产视频在线观看一区二区三区
|
亚洲综合不卡
|
欧美一区二区国产
|
国产精品日韩久久久
|
亚洲一区二区久久
|
久久精品国产精品亚洲
|
国产麻豆午夜三级精品
|
亚洲欧美日韩在线不卡
|
久久国产色av
|
在线观看日韩av先锋影音电影院
|
久久精品最新地址
|
免费在线播放第一区高清av
|
亚洲高清资源
|
欧美大秀在线观看
|
99精品99
|
久久久久免费观看
|
亚洲二区视频
|
欧美日韩国产色综合一二三四
|
夜夜夜久久久
|
久久国产精品一区二区三区四区
|
国自产拍偷拍福利精品免费一
|
久久久久久久综合日本
|
亚洲第一区中文99精品
|
一本一本久久a久久精品综合妖精
|
欧美色图首页
|
欧美一区午夜精品
|
亚洲第一页中文字幕
|
亚洲午夜极品
|
韩国成人福利片在线播放
|
美女精品网站
|
亚洲桃花岛网站
|
免费日韩av
|
亚洲一区二区视频在线
|
国语自产精品视频在线看
|
欧美电影免费
|
午夜精品久久久
|
亚洲成色777777在线观看影院
|
亚洲综合日韩在线
|
亚洲成人在线
|
国产欧美日韩视频一区二区三区
|
久久久久久久综合色一本
|
亚洲天堂成人在线视频
|
欧美刺激午夜性久久久久久久
|
亚洲在线观看
|
亚洲精品免费一区二区三区
|
国产欧美精品va在线观看
|
欧美成人精品在线
|
欧美一区二区女人
|
一区二区三区日韩精品
|
男女av一区三区二区色多
|
性欧美1819sex性高清
|
日韩视频一区二区三区
|
樱花yy私人影院亚洲
|
国产精品私房写真福利视频
|
蜜臀av性久久久久蜜臀aⅴ四虎
|
亚洲国产精品t66y
|
久久久久国产精品人
|
亚洲一区二区成人
|
亚洲国产一区二区三区高清
|
国产专区综合网
|
国产精品久久久久久妇女6080
|
欧美成人午夜剧场免费观看
|
久久久九九九九
|
性欧美暴力猛交69hd
|
亚洲视频导航
|
一区二区欧美亚洲
|
亚洲日本激情
|
亚洲乱码日产精品bd
|
亚洲国产天堂久久国产91
|
老牛嫩草一区二区三区日本
|
久久激情久久
|
久久久www成人免费精品
|
午夜老司机精品
|
亚洲欧美美女
|
欧美一区二视频
|
欧美一区网站
|
欧美一区三区二区在线观看
|
午夜在线精品
|
欧美在线二区
|
久久久久久亚洲精品不卡4k岛国
|
欧美一区中文字幕
|
久久精品国产精品亚洲精品
|
欧美在线日韩在线
|
久久久精品动漫
|
美女精品网站
|
欧美国产91
|
亚洲肉体裸体xxxx137
|
亚洲日本在线视频观看
|
亚洲伦理在线免费看
|
一区二区久久久久
|
亚洲欧美制服另类日韩
|
欧美中文字幕视频在线观看
|
久久gogo国模裸体人体
|
免费成人黄色
|
欧美伦理在线观看
|
国产精品日韩欧美一区二区三区
|
国产欧美一区视频
|
红桃视频国产精品
|
亚洲日本一区二区三区
|
亚洲无线一线二线三线区别av
|
亚洲一区三区视频在线观看
|
久久国产精品毛片
|
欧美xxx成人
|
一区二区三区四区五区精品
|
欧美亚洲视频一区二区
|
久久中文欧美
|
国产精品国产精品国产专区不蜜
|
国产欧美午夜
|
亚洲人成欧美中文字幕
|
香蕉亚洲视频
|
欧美二区乱c少妇
|
在线一区观看
|
久久久久久一区
|
欧美日韩在线不卡
|
一区精品在线播放
|
亚洲天堂视频在线观看
|
久久综合国产精品台湾中文娱乐网
|
亚洲第一狼人社区
|
午夜一区二区三区不卡视频
|
欧美不卡高清
|
激情久久婷婷
|
亚洲一品av免费观看
|
欧美va日韩va
|
午夜精品久久久99热福利
|
欧美精品自拍
|
在线成人免费视频
|
亚洲欧美激情一区
|
最新成人在线
|
久久人91精品久久久久久不卡
|
国产精品毛片a∨一区二区三区|国
|