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

            飯中淹的避難所~~~~~

            偶爾來避難的地方~

              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              94 隨筆 :: 0 文章 :: 257 評(píng)論 :: 0 Trackbacks

            在做跨平臺(tái)的網(wǎng)絡(luò)數(shù)據(jù)傳輸和文件數(shù)據(jù)轉(zhuǎn)換和移植的時(shí)候,經(jīng)常會(huì)碰到CPU字節(jié)序不同導(dǎo)致的各種各樣的問題.
            于是,在編寫平臺(tái)無關(guān),字符編碼無關(guān)的要求之外,又有一個(gè)新的對(duì)跨平臺(tái)編碼的要求,那就是字節(jié)序無關(guān).
            其實(shí)要實(shí)現(xiàn)這個(gè)也不難, 只要能夠檢測(cè)和轉(zhuǎn)換字節(jié)序, 就完全可以實(shí)現(xiàn).
            下面提供各一種方法來解決這兩個(gè)問題.

            //   檢測(cè)平臺(tái)的Endian
            typedef union uEndianTest{
             struct
             {
              bool flittle_endian;
              bool fill[3];
             };
             long value;
            }EndianTest;
            static const EndianTest __Endian_Test__ = { (long)1 };
            const bool platform_little_endian = __Endian_Test__.flittle_endian;

            這樣使用這個(gè) platform_little_endian 就可以檢測(cè)到當(dāng)前平臺(tái)是否是little_endian

            //   Endian 轉(zhuǎn)換(64位, 32位和16位的字節(jié)序轉(zhuǎn)換)
            //   中間使用了異或交換的算法
            //   使用方法舉例:
            //   long lValue = 0xff000000;
            //   ConvertEndian32( &lValue );
            //  
            inline void ConvertEndian64( LPVOID lpMem )
            {
             BYTE * p = (BYTE*)lpMem;
             p[0] = p[0] ^ p[7];
             p[7] = p[0] ^ p[7];
             p[0] = p[0] ^ p[7];

             p[1] = p[1] ^ p[6];
             p[6] = p[1] ^ p[6];
             p[1] = p[1] ^ p[6];

             p[2] = p[2] ^ p[5];
             p[5] = p[2] ^ p[5];
             p[2] = p[2] ^ p[5];

             p[3] = p[3] ^ p[4];
             p[4] = p[3] ^ p[4];
             p[3] = p[3] ^ p[4];
            }

            inline void ConvertEndian32( LPVOID lpMem )
            {
             BYTE * p = (BYTE*)lpMem;
             p[0] = p[0] ^ p[3];
             p[3] = p[0] ^ p[3];
             p[0] = p[0] ^ p[3];
             p[1] = p[1] ^ p[2];
             p[2] = p[1] ^ p[2];
             p[1] = p[1] ^ p[2];
            }

            inline void ConvertEndian16( LPVOID lpMem )
            {
             BYTE * p = (BYTE*)lpMem;
             p[0] = p[0] ^ p[1];
             p[1] = p[0] ^ p[1];
             p[0] = p[0] ^ p[1];
            }

            posted on 2007-04-18 12:21 飯中淹 閱讀(2343) 評(píng)論(1)  編輯 收藏 引用

            評(píng)論

            # re: 在C++中檢測(cè)和轉(zhuǎn)換字節(jié)序(ENDIAN) 2008-05-06 18:51 zyp
            非常感謝,幫我解決了大問題  回復(fù)  更多評(píng)論
              


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            亚洲AV乱码久久精品蜜桃| 久久免费小视频| 99久久精品国产一区二区| 日韩久久久久久中文人妻| 国产午夜精品理论片久久影视| 精品人妻伦九区久久AAA片69| 久久综合日本熟妇| 久久国产精品-久久精品| 婷婷久久精品国产| 国内精品人妻无码久久久影院 | 久久久www免费人成精品| 久久精品国产亚洲av影院| 香蕉99久久国产综合精品宅男自 | 综合人妻久久一区二区精品| 国产午夜精品理论片久久影视| 欧洲性大片xxxxx久久久| 久久国产高清字幕中文| 亚洲精品无码久久久久去q | 久久99国产综合精品| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 99久久做夜夜爱天天做精品| 亚洲午夜久久影院| 成人久久精品一区二区三区| 一级做a爰片久久毛片看看| 国内精品久久久久久中文字幕| 国内精品久久久久久久97牛牛| 久久人人爽人人爽人人片AV东京热| 国产精品久久久久久久久久免费| 久久99国产精品久久久| 久久精品国产亚洲AV高清热| 精品综合久久久久久97| 亚洲精品国产美女久久久| 一极黄色视频久久网站| 亚洲精品乱码久久久久久不卡| 无码任你躁久久久久久久| 久久精品国产亚洲精品| 日本久久中文字幕| 综合久久久久久中文字幕亚洲国产国产综合一区首| 色综合久久最新中文字幕| 91精品国产91久久久久久青草 | 久久久久久免费视频|