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

            最近學(xué)習(xí)了Apache MINA通訊,在使用過程中碰到了一些問題,記錄下一些心得。

            在服務(wù)端和客戶端都使用MINA提供的庫時,通訊一切正常,當(dāng)我把客戶端改為C++代碼時,發(fā)現(xiàn)客戶端發(fā)送給服務(wù)端的二進(jìn)制流中的整形數(shù)據(jù),位置被倒置了。

            C++客戶端16進(jìn)制  :0x00000013

            MINA服務(wù)端16進(jìn)制:0x13000000

            查詢了網(wǎng)上資料后才知道Java在所有平臺上都默認(rèn)是big-endian,而C++在不同的平臺上有不同的字節(jié)序, X86上是little-endian, solaris上是big-endian。

            注意問題:

            1、字節(jié)序

            C++在不同的平臺上有不同的字節(jié)序, X86上是little-endian, solaris上是big-endian; 而java在所有平臺上都默認(rèn)是big-endian, 所以在傳輸諸如short,int,long數(shù)據(jù)時要在C++轉(zhuǎn)換成網(wǎng)絡(luò)序(big-endian)
            2、字符編碼

            C++上最普遍的是采用mbcs, 而java上是用unicode(并且和標(biāo)準(zhǔn)的unicode還有些區(qū)別,可以參考java文檔), 所以除非必須否則不要傳字符串, 可以傳文本文件代替, 一定要傳的話只能自己轉(zhuǎn)換了
            3、 內(nèi)存對齊, 在C/C++的網(wǎng)絡(luò)通信程序中經(jīng)常采用讀寫結(jié)構(gòu)體的方式方便地交換數(shù)據(jù), 但是不注意的話結(jié)構(gòu)體內(nèi)很可能有空隙, 比如struct A{ int a; char c }; struct B{ char a; int b }; 這兩個結(jié)構(gòu)體內(nèi)都有空隙, 而如果不說明空隙的存在java程序是不會知道的, 就會導(dǎo)致雙方解析時出錯. 要消除空隙應(yīng)該小心地安排結(jié)構(gòu)體的成員, 不推薦使用#pragma pach(1), 因為沒有通用性
            4、 位域

            除非小心安排, 否則位域?qū)е碌慕Y(jié)構(gòu)體大小與平臺相關(guān), int a:4所占用的字節(jié)隨平臺和編譯器變化(char a:4相對穩(wěn)定占1字節(jié))
            5、 (可能平臺相關(guān))傳送與接收速度不同
            當(dāng)C++向java傳送一個大一些的數(shù)據(jù)時, 可能C++一邊已經(jīng)傳完退出了, 而java那邊還沒收完, 導(dǎo)致最后的一部分?jǐn)?shù)據(jù)丟失. 所以項目中采用了簡單的確認(rèn)機制, 任何一方接收完數(shù)據(jù)就回送1字節(jié)的確認(rèn), 以防止C++過早退出

            6、(可能平臺相關(guān))java在同C++建立連接后以及在C++向java傳送完一段數(shù)據(jù)后, java若向C++傳送一段數(shù)據(jù)則第一次傳送的數(shù)據(jù)C++只能收到一個字節(jié), 第一次過后恢復(fù)正常


            C++整形轉(zhuǎn)換代碼如下:

            void swap_4(unsigned long &x)  
            {  
                x 
            = (x << 24|  
                ((x 
            << 8& 0x00ff0000u|  
                ((x 
            >> 8& 0x0000ff00u|  
                (x 
            >> 24);  
            }  
              
            int _tmain(int argc, _TCHAR* argv[])  
            {  
                   
                 unsigned 
            long len = 19;  
                 swap_4(len);  
            }

            Feedback

            # re: MINA服務(wù)端與C++客戶端通訊(1)  回復(fù)  更多評論   

            2011-07-07 22:14 by 放屁阿狗
            1.大小數(shù)問題這是個跨平臺、網(wǎng)絡(luò)編程基礎(chǔ)概念,*nix一般都是大數(shù)優(yōu)先
            2.你說的這個我都沒聽明白,mbcs可以進(jìn)行任何編碼iconv,傳輸字符串編碼很多方式,utf8比較流行,也可以進(jìn)行壓縮,你可以參考一些通信軟件框架的消息編碼代碼,定義一個合適的協(xié)議格式封裝你所要傳遞的消息,比如rpc的xdr,ice通信協(xié)議
            3.c/c++這種允許直接內(nèi)存地址引用的語言,只有我在剛學(xué)會編程的開始會直接&obj的地址作為數(shù)據(jù)的首地址進(jìn)行異構(gòu)網(wǎng)絡(luò)的通信,采用#pragma這種方式來實現(xiàn)對其這是個很要命且很呆瓜的辦法,導(dǎo)致了諸多的問題,必須封裝成stream wrapper的方式來serialize數(shù)據(jù),比如java的writeUint32,writeString等等
            4.不知在說啥
            5.這個問題很好解決,c端發(fā)送完畢調(diào)用shutdown(1)實現(xiàn)半關(guān)閉,java那里就知道對點退出了,很多軟件都是這么做的,比如 hp-openview的sdk
            6.不知在說啥,網(wǎng)絡(luò)通信其實是個比較簡單的過程 ,熟悉posix標(biāo)準(zhǔn)的socket api就可以了,不存在語言差異問題

            # re: MINA服務(wù)端與C++客戶端通訊(1)  回復(fù)  更多評論   

            2011-07-08 09:26 by chugf
            @放屁阿狗
            非常感謝

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


            posts - 5, comments - 22, trackbacks - 0, articles - 0

            Copyright © chugf

            久久福利青草精品资源站| 久久久亚洲裙底偷窥综合| 久久se精品一区精品二区国产| 亚洲精品久久久www| 久久久久人妻一区二区三区| 色婷婷久久久SWAG精品| 亚洲人AV永久一区二区三区久久| 亚洲AV日韩AV永久无码久久| 国内高清久久久久久| 69SEX久久精品国产麻豆| 欧洲国产伦久久久久久久| 久久超碰97人人做人人爱| 青青青青久久精品国产h| 国内精品九九久久精品| 亚洲国产精品久久久久久| 漂亮人妻被黑人久久精品| 久久国产福利免费| 欧美精品一本久久男人的天堂| 热RE99久久精品国产66热| 久久精品国产亚洲av麻豆小说| 国内精品久久久久久99| 人妻无码αv中文字幕久久琪琪布 人妻无码精品久久亚瑟影视 | 久久综合欧美成人| 无码任你躁久久久久久老妇App| 久久精品国产亚洲沈樵| 久久综合久久伊人| 国产精品一久久香蕉国产线看观看 | 国内精品久久久久久久亚洲| 人妻无码αv中文字幕久久琪琪布 人妻无码精品久久亚瑟影视 | 久久久婷婷五月亚洲97号色| 久久久噜噜噜久久| 久久精品亚洲男人的天堂| 国产成人精品久久| 欧美亚洲国产精品久久蜜芽| 精品久久无码中文字幕| 精品久久久久久国产潘金莲| 国产精品九九久久免费视频| 日韩精品久久久久久| 久久精品人成免费| 伊人久久精品无码二区麻豆| 麻豆久久久9性大片|