• <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>
            隨筆-60  評論-98  文章-0  trackbacks-0
            最近在處理超大文件,用到了DWORD64

            期望用戶將偏移量以DWORD64的形式傳進來,然后我調用WindowsAPI進行定位,讀取文件,返回

            這是CB下的測試結果,沒有報錯,只給你返回一個錯誤的結果
            1// 是測試DWORD64右移32位會出現什么狀況
            2DOWRD64 dw6403 = 1024*1024*1024;
            3DWORD64 dw6404 = 2*1024*1024*1024;
            4UINT uTmp = 6403>>32// 0
            5uTmp = 6404>>32;      // oxFFFFFFFF

            // CB下編譯通過,結果正確
            1// 目的同上
            2DWORD64 dw641G = 1024*1024*1024;
            3DWORD64 dw6404 = 2*dw641G ;
            4UINT uTmp = dw6404>>32// 0

            結論:是兩家的編譯器在預編譯的時候,不允許數值超過1G。
            posted on 2010-02-02 20:09 創建更好的解決方案 閱讀(1872) 評論(9)  編輯 收藏 引用 所屬分類: C++專欄內存專題

            評論:
            # re: Visual Studio VS C++Builder07 不同的公司,同樣的Bug 2010-02-02 20:21 | 創建更好的解決方案
            // 更為離譜的事情發生了,同為10*1024*1024的兩個數值,由于一個是成員變量,一個是臨時變量,右移之后結果居然不同

            DWORD64 dw64Tmp = m_dw64FileSize;
            UINT dwTmp2 = (m_dw64FileSize>>32); // 還是10*1024*1024
            UINT dwTmp1 = (dw64Tmp>>32); // 0  回復  更多評論
              
            # re: Visual Studio VS C++Builder07 不同的公司,同樣的Bug[未登錄] 2010-02-02 23:14 | clear
            64位字面常量后面要加LL
            否則數字按照32位,乘法使用32位,結果溢出了。

            所以,這個不是編譯器bug。  回復  更多評論
              
            # re: Visual Studio VS C++Builder07 不同的公司,同樣的Bug 2010-02-03 10:42 | coolypf
            請問您懂匯編嗎?  回復  更多評論
              
            # re: Visual Studio VS C++Builder07 不同的公司,同樣的Bug 2010-02-03 11:38 | 空明流轉
            Literal Constant Suffix “L”啊同學。。。  回復  更多評論
              
            # re: Visual Studio VS C++Builder07 不同的公司,同樣的Bug 2010-02-03 12:06 | 創建更好的解決方案
            @clear
            2*1024*1024*1024,距離32位溢出,還有50步呢  回復  更多評論
              
            # re: Visual Studio VS C++Builder07 不同的公司,同樣的Bug 2010-02-03 13:56 | 試試其他的
            32位機器上整形最大是2^31 - 1。
            2*1024*1024*1024 溢出了。

            2LL*1024*1024*1024 才不溢出。明白?

            clear 的說法是正確的。 這么點屁事別放首頁。  回復  更多評論
              
            # re: Visual Studio VS C++Builder07 不同的公司,同樣的Bug 2010-02-03 14:38 | 創建更好的解決方案
            @試試其他的
            int和unsigned int表達范圍一樣嗎?
              回復  更多評論
              
            # re: Visual Studio VS C++Builder07 不同的公司,同樣的Bug 2010-02-05 13:20 | 喜樂遞官方網站
            愛上的卡就是覺得  回復  更多評論
              
            # re: Visual Studio VS C++Builder07 不同的公司,同樣的Bug 2010-02-05 16:50 | 試試其他的
            @創建更好的解決方案
            當然不一樣了。
            至于int和unsigned int范圍可以參見limits.h
            里面有INT_MIN,INT_MAX和UINT_MAX  回復  更多評論
              
            久久国产成人精品麻豆 | 99精品久久久久久久婷婷| 久久亚洲中文字幕精品有坂深雪 | 久久99久久成人免费播放| 丁香五月综合久久激情| 一本色道久久88综合日韩精品| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 欧美久久一区二区三区| 99精品久久精品一区二区| 久久99国产精品一区二区| 色99久久久久高潮综合影院| 色综合久久无码中文字幕| 久久99精品久久久久久秒播| 7777久久久国产精品消防器材| 情人伊人久久综合亚洲| 欧美久久久久久| 久久亚洲精品视频| 亚洲国产精品无码久久久蜜芽 | 污污内射久久一区二区欧美日韩| 久久精品国产亚洲av高清漫画| 久久AAAA片一区二区| 99999久久久久久亚洲| 久久亚洲AV无码精品色午夜| 99久久精品国产一区二区| 久久99久久99精品免视看动漫| 狠狠色丁香婷婷久久综合五月| 国产精品久久久天天影视香蕉| 精品免费久久久久久久| 一本色道久久综合亚洲精品| 亚洲一区精品伊人久久伊人| 日韩中文久久| 亚洲精品国产自在久久| 欧洲国产伦久久久久久久| AAA级久久久精品无码区| 久久青青草原综合伊人| 91精品国产91久久久久久| 国产精品久久国产精麻豆99网站| 亚洲欧美日韩久久精品第一区| 一本色道久久99一综合| 亚洲AV无码久久| 久久精品蜜芽亚洲国产AV|