• <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>

            MyMSDN

            MyMSDN記錄開(kāi)發(fā)新知道

            size_t的倒序遍歷問(wèn)題

            準(zhǔn)確地說(shuō)還是經(jīng)驗(yàn)不足,這么簡(jiǎn)單的事居然想了好幾分鐘,當(dāng)然也要怪VS在沒(méi)有重新生成前的詭異現(xiàn)象。

            今晚在類中加入兩個(gè)數(shù)組用來(lái)做計(jì)數(shù),因?yàn)橹按a有所改動(dòng),VS編譯(增量)的結(jié)果居然出現(xiàn)了無(wú)數(shù)次的程序崩潰,害我一度懷疑是不是我的數(shù)組寫的有問(wèn)題。囧。最后無(wú)奈之下,點(diǎn)了重新生成,居然順利通過(guò)了,很生氣,憤怒中。

            但是另外卻發(fā)現(xiàn)了一個(gè)問(wèn)題,也就是當(dāng)size_t用作循環(huán)的時(shí)候。因?yàn)橐郧岸际怯胕nt做循環(huán)的,現(xiàn)在換成unsigned int(也就是size_t)后,一下子沒(méi)反應(yīng)過(guò)來(lái),就順手這么寫了:

             

            for( size_t i = MAX - 1; i >= 0; --i)

            {

            //……

            }

            乍一看似乎沒(méi)啥問(wèn)題,因?yàn)槲已h(huán)內(nèi)的代碼是刪除資源的,因此程序也頻頻崩潰。

            step over的結(jié)果才讓人驚訝,因?yàn)楫?dāng)size_t i = 0的時(shí)候,--i的結(jié)果是無(wú)窮大,而無(wú)窮大則肯定滿足i>=0的條件,所以當(dāng)我們期待程序停住的時(shí)候,程序是不會(huì)停住的。

            修正的方式:

            1、使用正向遍歷。

            2、增加判斷條件(i>=0 && i < MAX),但這里也可能存在問(wèn)題,因?yàn)閟ize_t可能被定義為unsigned int,但是MAX可能是個(gè)更大的數(shù),比如unsigned long long,當(dāng)然這樣的比較不是很有意義,或者會(huì)實(shí)現(xiàn)一些轉(zhuǎn)換,但是如果這種情況發(fā)生的話,程序可能還是會(huì)通過(guò)一個(gè)隨機(jī)的i進(jìn)入到一個(gè)未知的空間中,從而造成崩潰。而且增加判斷條件也使得程序的運(yùn)行成本提高。

            posted on 2010-06-30 23:51 volnet 閱讀(1155) 評(píng)論(11)  編輯 收藏 引用 所屬分類: C/C++

            評(píng)論

            # re: size_t的倒序遍歷問(wèn)題 2010-07-01 08:52 egmkang

            換成int即可

            我同事之前也犯過(guò)這個(gè)錯(cuò)誤  回復(fù)  更多評(píng)論   

            # re: size_t的倒序遍歷問(wèn)題 2010-07-01 09:16 volnet

            @egmkang
            我應(yīng)該沒(méi)發(fā)到首頁(yè)去吧,你咋能看得到呢?  回復(fù)  更多評(píng)論   

            # re: size_t的倒序遍歷問(wèn)題[未登錄](méi) 2010-07-01 13:30 Tiger

            學(xué)習(xí)了,的確是在主頁(yè)上看到的@volnet
              回復(fù)  更多評(píng)論   

            # re: size_t的倒序遍歷問(wèn)題 2010-07-01 14:10 volnet

            @Tiger
            可是我怎么看不到呢?您能截圖一下么,太奇怪了  回復(fù)  更多評(píng)論   

            # re: size_t的倒序遍歷問(wèn)題 2010-07-01 17:33 OwnWaterloo

            for (size_t i=n; i-- /*!=0*/; )
            ...  回復(fù)  更多評(píng)論   

            # re: size_t的倒序遍歷問(wèn)題 2010-07-01 23:58 volnet

            @OwnWaterloo
            好像不錯(cuò)  回復(fù)  更多評(píng)論   

            # re: size_t的倒序遍歷問(wèn)題 2010-07-07 09:13 egmkang

            @volnet
            牛人的,總歸要訂閱哈  回復(fù)  更多評(píng)論   

            # shi 2010-08-23 16:34 uk dress

            That's good  回復(fù)  更多評(píng)論   

            # re: size_t的倒序遍歷問(wèn)題 2010-08-29 17:25 evening dresses

            換成int即可
              回復(fù)  更多評(píng)論   

            # re: size_t的倒序遍歷問(wèn)題 2010-08-29 17:30 evening dresses

            題,因?yàn)閟ize_t可能被定義為unsigned int,但是MAX可能是個(gè)更大的數(shù),比如unsigned long long,當(dāng)然這樣的比較不是很有意義,或者會(huì)實(shí)現(xiàn)一些轉(zhuǎn)換,但是如果這種情況發(fā)生的話,程序可能還是會(huì)通過(guò)一個(gè)隨機(jī)  回復(fù)  更多評(píng)論   

            # shi 2010-10-27 17:44 uk dress

            good job  回復(fù)  更多評(píng)論   

            特殊功能
             
            久久成人国产精品| 久久精品国产亚洲AV香蕉| 久久伊人精品青青草原高清| avtt天堂网久久精品| 精品人妻伦九区久久AAA片69| 国产一区二区三精品久久久无广告| 精品久久综合1区2区3区激情| 久久久噜噜噜久久| 亚洲精品国产美女久久久| 久久久精品午夜免费不卡| 热RE99久久精品国产66热| 久久久久久午夜成人影院| 人妻无码精品久久亚瑟影视| 久久综合给合久久国产免费| 久久国产香蕉视频| 久久99久久99精品免视看动漫| 久久婷婷国产麻豆91天堂| 7777久久久国产精品消防器材| 精品久久久久一区二区三区| 精品无码久久久久国产| 久久亚洲精品成人无码网站| 国产成人精品久久| 精品久久久久久国产潘金莲| 伊人久久大香线蕉综合网站| 久久香蕉国产线看观看乱码| 久久精品天天中文字幕人妻| 久久久久亚洲AV无码观看| 久久午夜无码鲁丝片午夜精品| 欧美亚洲国产精品久久蜜芽| 久久精品国产99久久无毒不卡 | 麻豆精品久久久久久久99蜜桃| av国内精品久久久久影院| 日韩精品久久久肉伦网站| 亚洲国产成人久久一区WWW| 久久久网中文字幕| 久久久久亚洲爆乳少妇无| 国内精品久久久久久久涩爱| 国产精品gz久久久| 午夜精品久久影院蜜桃| 久久亚洲精品国产精品婷婷 | 亚洲人成网亚洲欧洲无码久久|