• <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記錄開發新知道

            size_t的倒序遍歷問題

            準確地說還是經驗不足,這么簡單的事居然想了好幾分鐘,當然也要怪VS在沒有重新生成前的詭異現象。

            今晚在類中加入兩個數組用來做計數,因為之前代碼有所改動,VS編譯(增量)的結果居然出現了無數次的程序崩潰,害我一度懷疑是不是我的數組寫的有問題。囧。最后無奈之下,點了重新生成,居然順利通過了,很生氣,憤怒中。

            但是另外卻發現了一個問題,也就是當size_t用作循環的時候。因為以前都是用int做循環的,現在換成unsigned int(也就是size_t)后,一下子沒反應過來,就順手這么寫了:

             

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

            {

            //……

            }

            乍一看似乎沒啥問題,因為我循環內的代碼是刪除資源的,因此程序也頻頻崩潰。

            step over的結果才讓人驚訝,因為當size_t i = 0的時候,--i的結果是無窮大,而無窮大則肯定滿足i>=0的條件,所以當我們期待程序停住的時候,程序是不會停住的。

            修正的方式:

            1、使用正向遍歷。

            2、增加判斷條件(i>=0 && i < MAX),但這里也可能存在問題,因為size_t可能被定義為unsigned int,但是MAX可能是個更大的數,比如unsigned long long,當然這樣的比較不是很有意義,或者會實現一些轉換,但是如果這種情況發生的話,程序可能還是會通過一個隨機的i進入到一個未知的空間中,從而造成崩潰。而且增加判斷條件也使得程序的運行成本提高。

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

            評論

            # re: size_t的倒序遍歷問題 2010-07-01 08:52 egmkang

            換成int即可

            我同事之前也犯過這個錯誤  回復  更多評論   

            # re: size_t的倒序遍歷問題 2010-07-01 09:16 volnet

            @egmkang
            我應該沒發到首頁去吧,你咋能看得到呢?  回復  更多評論   

            # re: size_t的倒序遍歷問題[未登錄] 2010-07-01 13:30 Tiger

            學習了,的確是在主頁上看到的@volnet
              回復  更多評論   

            # re: size_t的倒序遍歷問題 2010-07-01 14:10 volnet

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

            # re: size_t的倒序遍歷問題 2010-07-01 17:33 OwnWaterloo

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

            # re: size_t的倒序遍歷問題 2010-07-01 23:58 volnet

            @OwnWaterloo
            好像不錯  回復  更多評論   

            # re: size_t的倒序遍歷問題 2010-07-07 09:13 egmkang

            @volnet
            牛人的,總歸要訂閱哈  回復  更多評論   

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

            That's good  回復  更多評論   

            # re: size_t的倒序遍歷問題 2010-08-29 17:25 evening dresses

            換成int即可
              回復  更多評論   

            # re: size_t的倒序遍歷問題 2010-08-29 17:30 evening dresses

            題,因為size_t可能被定義為unsigned int,但是MAX可能是個更大的數,比如unsigned long long,當然這樣的比較不是很有意義,或者會實現一些轉換,但是如果這種情況發生的話,程序可能還是會通過一個隨機  回復  更多評論   

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

            good job  回復  更多評論   

            特殊功能
             
            久久99精品久久久久久hb无码| 精品熟女少妇aⅴ免费久久| 色综合久久久久无码专区| 国产综合免费精品久久久| 91精品国产91热久久久久福利 | 久久精品国产亚洲av日韩| 久久久国产精品亚洲一区| 精品久久久久久无码人妻蜜桃| yy6080久久| 亚洲一级Av无码毛片久久精品| 伊人丁香狠狠色综合久久| 一本一本久久A久久综合精品| 国产精品久久久久蜜芽| 久久精品天天中文字幕人妻| 国产精品久久久久aaaa| 久久亚洲中文字幕精品一区| 久久天天躁狠狠躁夜夜躁2014| 久久精品国产亚洲av影院| 国产成人精品久久一区二区三区av| 国产午夜久久影院| 亚洲精品乱码久久久久久蜜桃| 久久久久久综合网天天| 亚洲成色WWW久久网站| 久久精品国产99久久丝袜| 久久久久高潮综合影院| 国产V亚洲V天堂无码久久久| 国产精品久久久久久久久免费| 久久久久久国产a免费观看不卡| 国内高清久久久久久| 中文字幕亚洲综合久久| 亚洲va中文字幕无码久久不卡| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 亚洲国产成人精品久久久国产成人一区二区三区综 | 欧美与黑人午夜性猛交久久久 | 久久久久亚洲AV综合波多野结衣 | 日韩欧美亚洲综合久久影院Ds | 亚洲欧美久久久久9999| 国产ww久久久久久久久久| 久久免费视频观看| 大蕉久久伊人中文字幕| 91精品国产综合久久香蕉|