• <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++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              94 隨筆 :: 0 文章 :: 257 評論 :: 0 Trackbacks

            在做跨平臺的網絡數據傳輸和文件數據轉換和移植的時候,經常會碰到CPU字節序不同導致的各種各樣的問題.
            于是,在編寫平臺無關,字符編碼無關的要求之外,又有一個新的對跨平臺編碼的要求,那就是字節序無關.
            其實要實現這個也不難, 只要能夠檢測和轉換字節序, 就完全可以實現.
            下面提供各一種方法來解決這兩個問題.

            //   檢測平臺的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;

            這樣使用這個 platform_little_endian 就可以檢測到當前平臺是否是little_endian

            //   Endian 轉換(64位, 32位和16位的字節序轉換)
            //   中間使用了異或交換的算法
            //   使用方法舉例:
            //   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 飯中淹 閱讀(2349) 評論(1)  編輯 收藏 引用

            評論

            # re: 在C++中檢測和轉換字節序(ENDIAN) 2008-05-06 18:51 zyp
            非常感謝,幫我解決了大問題  回復  更多評論
              

            69SEX久久精品国产麻豆| 亚洲精品美女久久久久99| 99久久精品这里只有精品 | 久久综合狠狠综合久久激情 | 久久成人18免费网站| 伊人久久久AV老熟妇色| 免费国产99久久久香蕉| 伊人久久成人成综合网222| 久久66热人妻偷产精品9| 伊人色综合久久天天网| 久久精品成人免费网站| 久久精品国产亚洲αv忘忧草| 99久久精品毛片免费播放| 亚洲午夜精品久久久久久浪潮 | 欧美精品久久久久久久自慰| 国产精品狼人久久久久影院| 久久综合九色综合网站| 伊人色综合久久天天网 | 精品久久久久久亚洲精品| 欧美午夜A∨大片久久 | 狠狠色丁香久久婷婷综合五月| 欧美国产成人久久精品| 久久免费视频网站| 精品久久久久久无码专区不卡| 久久无码AV一区二区三区| 久久www免费人成精品香蕉| 久久精品人人做人人爽电影| 精品久久久无码人妻中文字幕豆芽 | 69国产成人综合久久精品| 无码超乳爆乳中文字幕久久| 狠狠色丁香久久婷婷综合蜜芽五月| 久久久无码精品午夜| 影音先锋女人AV鲁色资源网久久 | 国产高清国内精品福利99久久| 亚洲精品国产字幕久久不卡| 久久精品国产AV一区二区三区| 久久久久亚洲精品天堂久久久久久 | 日本精品久久久中文字幕| 97精品伊人久久大香线蕉app| 精品久久人妻av中文字幕| 久久综合欧美成人|