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

Focus on ACE

訂閱 ace-china
電子郵件:
瀏覽存于 groups.google.com 上的所有帖子

C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
  64 Posts :: 3 Stories :: 22 Comments :: 0 Trackbacks


在Huihoo的ACE論壇中,有一網(wǎng)友問到為什么ACE_Time_Value的秒數(shù)在Debug版本少一秒,而
在Release版本上“正常”。經(jīng)過對(duì)其代碼的復(fù)讀以及對(duì)ACE的跟蹤,發(fā)現(xiàn)原來是編碼不規(guī)范犯
下的一個(gè)很嚴(yán)重的錯(cuò)誤造成的。本文就討論這一例子。

以下引用
?

?1?/*
?2?我寫了個(gè)從年月日時(shí)分秒數(shù)值得到ACE_Time_Value結(jié)果的函數(shù):
?3?*/
?4?long?s_get_ace_datetime(ACE_Time_Value?&?ace_datetime,
?5???????int?year,
?6???????int?month,
?7???????int?day,
?8???????int?hour,
?9???????int?min,
10???????int?sec)
11?{
12?????if(year<1970?||?year>2038?||?month<1?||?month>12?||?day<1?||?day>31?||
13?????????hour<0?||?hour>23?||?min<0?||?min>59?||?sec<0?||?sec>59)
14???????????ACE_ERROR_RETURN((LM_ERROR,
15??????????????????????????ACE_TEXT("%I(日期時(shí)間參數(shù)溢出合理的習(xí)慣日期時(shí)間范圍1970.1.2-2038.1.18)n")),-1);
16?????timespec_t?spec_t;
17?????tm?time_tm;?
18???time_tm.tm_year=year-1900;
19???time_tm.tm_mon=month-1;
20???time_tm.tm_mday=day;
21???time_tm.tm_hour=hour;
22???time_tm.tm_min=min;
23???#if?defined?(ACE_NDEBUG)
24?????time_tm.tm_sec=sec;
25???#else
26?????time_tm.tm_sec=sec+1;?//奇怪,當(dāng)由各部分?jǐn)?shù)量構(gòu)造ACE_Time_Value時(shí),debug編譯時(shí),秒的數(shù)量總是自動(dòng)減1,在此要補(bǔ)上1
27???#endif
28????spec_t.tv_sec=mktime(&time_tm);?
29????if(spec_t.tv_sec<0)
30????ACE_ERROR_RETURN((LM_ERROR,ACE_TEXT("%I(日期時(shí)間轉(zhuǎn)化錯(cuò)誤,得到<0的time_t,日期范圍是1970.1.2-2038.1.18)n")),-1);
31????ace_datetime.set(spec_t);
32????return?0;
33?}
34?/*
35?我在VC++7.1上分別編譯了Debug版本和Release版本,time_tm.tm_sec竟然會(huì)有一秒的差別,莫名其妙地影響了我的項(xiàng)目.
36?哪位高手知道為什么?
37?另外ACE_Time_Value的范圍太小,ACE中是否有大日期時(shí)間范圍的其它類封裝?
38?*/

以下是我的回貼:

你這個(gè)問題還真有趣,我跟蹤了ACE相關(guān)代碼后才發(fā)現(xiàn),問題原來出在你寫的函數(shù)中,病因是,使用未完全初始化的結(jié)構(gòu)體變量

timespec_t?spec_t;
后面加上語句
memset(
&spec_t ,0,sizeof(timespec_t));
即可

局部變量?spec_t?在debug時(shí),各字段均被初始化為0xCCCCCCCC,它是一個(gè)負(fù)數(shù)
在下面的操作中,只修改了tv_sec,而tv_nsec?仍為一個(gè)負(fù)數(shù)
spec_t.tv_sec=mktime(
&time_tm );?


ACE_Time_Value::normalize()默默地為你作了規(guī)格化處理,就替你減去了一秒鐘。





原代碼更嚴(yán)重的錯(cuò)誤在于:
原以為 Release版本是“正常”的,其實(shí)不然,而是Release隱藏了更嚴(yán)重的錯(cuò)誤。
嚴(yán)重是因?yàn)樗憩F(xiàn)出錯(cuò)誤的時(shí)候很隨機(jī),一旦產(chǎn)品發(fā)布,很難發(fā)現(xiàn)。

// 對(duì)象(結(jié)構(gòu)體)timespec有兩個(gè)公有屬性
?typedef? struct ?timespec
?????
{
???????time_t?tv_sec;?
// ?Seconds
??????? long ?tv_nsec;? // ?Nanoseconds,?十億分之一秒
?????}
?timespec_t;
?????

在原代碼16行
timespec_t spec_t;
構(gòu)造了一個(gè) timespec_t? 臨時(shí)對(duì)象spec_t后,debug版把它各字段初始化為 0xcccccccc,這使得問題一下子得于曝光.而Release版本, spec_t 為一個(gè)隨機(jī)值. 本例程中,不允許 spec_t的tv_nsec為非0的任何數(shù),為正常盡管看上去沒有問題,但是這個(gè)對(duì)應(yīng)的ACE_Time_Value的值也不可靠.在特定情況下可能產(chǎn)生重大事故.

C++編碼規(guī)范:
初始化對(duì)象時(shí)要完全。

聲明一個(gè)結(jié)構(gòu)體后,如果要對(duì)其初始化,建議先把它設(shè)為0之后再作后續(xù)操作,養(yǎng)成這樣一個(gè)習(xí)慣,就不會(huì)出現(xiàn)這樣郁悶的事了。


原貼出處:
http://www.huihoo.com/forum/viewthread.php?tid=11016


mooyee

posted on 2006-04-11 15:29 Stone Jiang 閱讀(1409) 評(píng)論(1)  編輯 收藏 引用 所屬分類: ACEC++&OOP

Feedback

# re: C++編碼不規(guī)范出現(xiàn)的錯(cuò)誤一例的解析 2010-07-01 09:41 mymtom
sec<0 || sec>59
是不對(duì)的.應(yīng)該是
sec<0 || sec>60
  回復(fù)  更多評(píng)論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美精品九九| 国产精品麻豆va在线播放| 国产精品三级久久久久久电影| 国产一区二区三区最好精华液| 国产视频久久| 亚洲欧美一区二区精品久久久| 牛牛国产精品| 欧美在线观看你懂的| 国产精品久久久久久久一区探花 | 欧美粗暴jizz性欧美20| 樱花yy私人影院亚洲| 午夜日韩在线| 亚洲午夜电影| 国产欧美日本| 欧美一区二区三区免费看| 99视频精品| 欧美日韩一区二区三区在线| 一本一道久久综合狠狠老精东影业| 噜噜噜在线观看免费视频日韩| 久久国产88| 黑人操亚洲美女惩罚| 久久免费的精品国产v∧| 久久精品国产清高在天天线| 国产又爽又黄的激情精品视频| 久久亚洲精品视频| 欧美成人一区二区三区在线观看 | 亚洲视频999| 国产精品久久久久秋霞鲁丝| 亚洲一区二区三区免费观看| 午夜精品成人在线视频| 黑人巨大精品欧美一区二区小视频| 久久久久综合网| 老司机一区二区三区| 日韩一级片网址| 亚洲一区二区在线看| 国产视频欧美视频| 亚洲国产日韩在线一区模特| 欧美色精品天天在线观看视频| 亚洲欧美综合| 欧美a级片网| 欧美在线免费一级片| 免费观看成人www动漫视频| 亚洲深夜av| 老司机午夜免费精品视频| 亚洲天堂免费观看| 久热精品视频在线观看一区| 亚洲手机视频| 欧美丰满高潮xxxx喷水动漫| 欧美一区综合| 欧美日韩国产va另类| 美日韩在线观看| 国产精品视频区| 免费观看日韩| 国产亚洲欧美日韩日本| 一本色道**综合亚洲精品蜜桃冫| 在线观看福利一区| 久久精品在线观看| 久久蜜桃资源一区二区老牛| 国产精品免费福利| 一区二区三区 在线观看视频| 韩国福利一区| 欧美中文字幕在线播放| 性做久久久久久| 国产乱码精品一区二区三区av| 欧美电影在线观看| 在线电影国产精品| 久久综合亚州| 亚洲成色999久久网站| 亚洲欧洲免费视频| 欧美~级网站不卡| 亚洲精品久久久久久久久| 一区二区三区不卡视频在线观看| 欧美成年人网站| 一区二区激情视频| 艳女tv在线观看国产一区| 欧美片第一页| 午夜精品久久久久久99热软件| 久久精品国产77777蜜臀| 一区二区三区在线免费观看 | 亚洲在线观看免费| 国产一区二区三区免费在线观看 | 久久国产手机看片| 在线观看欧美精品| 欧美金8天国| 性做久久久久久久久| 欧美丰满高潮xxxx喷水动漫| 日韩五码在线| 国产视频久久久久久久| 欧美成人免费在线| 亚洲午夜在线视频| 欧美成人中文字幕| 欧美一区日韩一区| 野花国产精品入口| 伊甸园精品99久久久久久| 欧美日韩黄色大片| 久久久久免费| 欧美在线视频导航| 一区二区三区国产盗摄| 欧美激情aⅴ一区二区三区| 欧美一区二区三区视频免费播放| 亚洲国产成人在线播放| 国产性做久久久久久| 欧美日韩国产一级| 蜜桃av噜噜一区二区三区| 亚洲视频久久| 夜夜嗨av一区二区三区中文字幕| 欧美 亚欧 日韩视频在线| 欧美一区国产一区| 欧美有码在线视频| 亚洲欧美日韩精品久久亚洲区| 99国内精品久久| 亚洲精品国产精品乱码不99| 亚洲激情视频在线观看| 韩日欧美一区| 亚洲国内精品在线| 亚洲人成在线观看一区二区| 亚洲人成网站999久久久综合 | 国内在线观看一区二区三区| 欧美三级日本三级少妇99| 欧美日韩国产综合视频在线观看| 免费国产自线拍一欧美视频| 欧美h视频在线| 欧美日韩国产区| 国产精品理论片在线观看| 国产精品入口66mio| 国产精品香蕉在线观看| 国产日韩精品视频一区二区三区 | 美乳少妇欧美精品| 亚洲国产精品v| 一区二区三区免费看| 欧美一级理论性理论a| 蜜桃av久久久亚洲精品| 欧美日韩午夜激情| 国产一区二区三区久久久| 亚洲欧洲久久| 亚洲欧美中文字幕| 亚洲国产精品一区二区第一页 | 你懂的国产精品| 亚洲欧美一区二区原创| 欧美日韩视频在线第一区| 1024欧美极品| 久久综合免费视频影院| 亚洲影院在线| 国产精品自在欧美一区| 亚洲一级黄色片| 亚洲日本电影| 欧美日本亚洲视频| 日韩视频永久免费观看| 欧美不卡一卡二卡免费版| 久久精品99| 伊人久久大香线蕉综合热线| 久久久久成人精品| 欧美亚洲综合在线| 国精品一区二区三区| 久久综合一区| 另类激情亚洲| 夜夜嗨av一区二区三区四区| 91久久国产精品91久久性色| 欧美精品二区| 亚洲尤物在线| 久久精品1区| 91久久精品久久国产性色也91| 亚洲黄色av一区| 国产精品xvideos88| 欧美综合国产精品久久丁香| 久久久久久久一区| 99视频精品全国免费| 亚洲综合另类| 亚洲电影在线播放| 日韩一本二本av| 韩国精品在线观看| 99精品欧美一区二区三区综合在线| 欧美日韩的一区二区| 久久gogo国模啪啪人体图| 裸体一区二区| 午夜伦欧美伦电影理论片| 久久视频一区二区| 香港成人在线视频| 欧美精品色综合| 美女亚洲精品| 国产日韩在线一区| 一本久久综合亚洲鲁鲁五月天| 狠狠色狠狠色综合人人| 一本色道久久综合狠狠躁篇的优点| 国产一区激情| 小辣椒精品导航| 先锋影音网一区二区| 欧美人与性动交cc0o| 嫩草伊人久久精品少妇av杨幂| 国产欧美一区二区精品婷婷| aa成人免费视频| 日韩亚洲欧美成人| 欧美 亚欧 日韩视频在线| 久久影院亚洲| 好看的日韩视频| 狂野欧美性猛交xxxx巴西| 久久婷婷av| 亚洲电影av| 欧美精品激情blacked18| 亚洲国产精品t66y|