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

            笑看風(fēng)云淡

            寵辱不驚,看庭前花開花落;去留無意,望天空云卷云舒
            posts - 96, comments - 48, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 ::  :: 聚合  :: 管理

            C/C++的64位整型

            Posted on 2009-12-24 15:44 天之驕子 閱讀(798) 評論(0)  編輯 收藏 引用

            在C/C++中,64為整型一直是一種沒有確定規(guī)范的數(shù)據(jù)類型。現(xiàn)今主流的編譯器中,對64為整型的支持也是標(biāo)準(zhǔn)不一,形態(tài)各異。一般來說,64位整型的定義方式有l(wèi)ong long和__int64兩種(VC還支持_int64),而輸出到標(biāo)準(zhǔn)輸出方式有printf(“%lld”,a),printf(“%I64d”,a),和cout << a三種方式。

            本文討論的是五種常用的C/C++編譯器對64位整型的支持,這五種編譯器分別是gcc(mingw32),g++(mingw32),gcc(linux i386),g++(linux i386),Microsoft Visual C++ 6.0??上У氖牵?strong>沒有一種定義和輸出方式組合,同時(shí)兼容這五種編譯器。為徹底弄清不同編譯器對64位整型,我寫了程序?qū)λ鼈冞M(jìn)行了評測,結(jié)果如下表。

            變量定義 輸出方式 gcc(mingw32) g++(mingw32) gcc(linux i386) g++(linux i386) MicrosoftVisual C++ 6.0
            long long “%lld” 錯(cuò)誤 錯(cuò)誤 正確 正確 無法編譯
            long long “%I64d” 正確 正確 錯(cuò)誤 錯(cuò)誤 無法編譯
            __int64 “lld” 錯(cuò)誤 錯(cuò)誤 無法編譯 無法編譯 錯(cuò)誤
            __int64 “%I64d” 正確 正確 無法編譯 無法編譯 正確
            long long cout 非C++ 正確 非C++ 正確 無法編譯
            __int64 cout 非C++ 正確 非C++ 無法編譯 無法編譯
            long long printint64() 正確 正確 正確 正確 無法編譯

            上表中,正確指編譯通過,運(yùn)行完全正確;錯(cuò)誤指編譯雖然通過,但運(yùn)行結(jié)果有誤;無法編譯指編譯器根本不能編譯完成。觀察上表,我們可以發(fā)現(xiàn)以下幾點(diǎn):

            1. long long定義方式可以用于gcc/g++,不受平臺(tái)限制,但不能用于VC6.0。
            2. __int64是Win32平臺(tái)編譯器64位長整型的定義方式,不能用于Linux。
            3. “%lld”用于Linux i386平臺(tái)編譯器,”%I64d”用于Win32平臺(tái)編譯器。
            4. cout只能用于C++編譯,在VC6.0中,cout不支持64位長整型。

            表中最后一行輸出方式中的printint64()是我自己寫的一個(gè)函數(shù),可以看出,它的兼容性要好于其他所有的輸出方式,它是一段這樣的代碼:

            void printint64(long long a)
                        {
                        if (a<=100000000)
                        printf("%d\n",a);
                        else
                        {
                        printf("%d",a/100000000);
                        printf("%08d\n",a%100000000);
                        }
                        }

            這種寫法的本質(zhì)是把較大的64位整型拆分為兩個(gè)32位整型,然后依次輸出,低位的部分要補(bǔ)0??此坪鼙康膶懛?,效果如何?我把它和cout輸出方式做了比較,因?yàn)樗蚦out都是C++支持跨平臺(tái)的。首先printint64()和cout(不清空緩沖區(qū))的運(yùn)行結(jié)果是完全相同的,不會(huì)出現(xiàn)錯(cuò)誤。我的試驗(yàn)是分別用兩者輸出1000000個(gè)隨機(jī)數(shù),實(shí)際結(jié)果是,printint64()在1.5s內(nèi)跑完了程序,而cout需要2s。cout要稍慢一些,所以在輸出大量數(shù)據(jù)時(shí),要盡量避免使用。

            久久99精品久久久久久9蜜桃| 亚洲国产美女精品久久久久∴| 久久精品国产亚洲AV嫖农村妇女| 久久精品国产久精国产果冻传媒| 亚洲欧洲久久av| 精品国产婷婷久久久| 亚洲va久久久噜噜噜久久男同| 99久久精品日本一区二区免费| 亚洲一本综合久久| 人妻无码αv中文字幕久久琪琪布 人妻无码精品久久亚瑟影视 | 青草国产精品久久久久久| 久久99精品九九九久久婷婷| 影音先锋女人AV鲁色资源网久久| 久久99精品久久久久久9蜜桃| 亚洲AV乱码久久精品蜜桃| 亚洲&#228;v永久无码精品天堂久久| 国产精品久久久久久久人人看| 色综合久久久久| 狠狠久久综合| 午夜精品久久久久| 伊人久久无码精品中文字幕| 久久亚洲日韩看片无码| 久久频这里精品99香蕉久| 日韩亚洲欧美久久久www综合网| 国产精品久久午夜夜伦鲁鲁| 久久久无码一区二区三区| 国产精品久久影院| 国产精品gz久久久| 久久国产亚洲精品| 久久久久久毛片免费播放| 日本福利片国产午夜久久| 亚洲国产成人久久笫一页 | 99麻豆久久久国产精品免费| 久久精品国产亚洲77777| 国产午夜精品久久久久九九电影| 久久婷婷五月综合色99啪ak| 亚洲日本va中文字幕久久| 久久精品成人国产午夜| 一本色综合网久久| 亚洲а∨天堂久久精品9966| 午夜视频久久久久一区|