研究背景及目的:

ARPG項(xiàng)目的需求:需要將現(xiàn)有的服務(wù)器從C++的編寫平臺(tái)換為java語言。
在對需求進(jìn)行分析的過程中,發(fā)現(xiàn)幾點(diǎn)需要研究實(shí)現(xiàn)的問題

  1. java與c+語言特性迥異,相比c+ 和c#關(guān)系的密切性,java需要對c#風(fēng)格的一些數(shù)據(jù)結(jié)構(gòu)和編碼格式進(jìn)行兼容;
  2. c#擁有的無符號(hào)數(shù)據(jù)類型如 ushort unint java并不存在,需要對數(shù)據(jù)類型進(jìn)行轉(zhuǎn)換;
  3. 根據(jù)開發(fā)需要 客戶端現(xiàn)有的通信協(xié)議不能更改,所以在java中進(jìn)行各類型的兼容操作
  4. 在項(xiàng)目中底層通信報(bào)文的類 是由名叫PROTOGEN的現(xiàn)有工程進(jìn)行生成,生成方式是以生成字符串文本類的方式,原工程已經(jīng)可以同時(shí)生成c#及c++的類(.cs及.h文件),但并沒有生成遷移后的服務(wù)器java的相關(guān)代碼和類的功能。故需要二次開發(fā)。

工作任務(wù):

綜上所述,工作任務(wù)有兩點(diǎn):

  1. 重構(gòu)java的 數(shù)據(jù)流輸入和輸出類,使其兼容c#客戶端傳輸過來的 二進(jìn)制數(shù)據(jù)結(jié)構(gòu);(以下簡稱PJIO)
  2. 對PROTOGEN進(jìn)行二次開發(fā),使其能夠生成java的 底層協(xié)議類(.java文件),并不破壞其現(xiàn)有生成其他語言的類的功能;(以下簡稱PGPLUS)
  3. 進(jìn)行測試和驗(yàn)證,確保前兩項(xiàng)工作任務(wù)的有效和后續(xù)開發(fā)工作的順利開展。

 

工作開展中遇到的技術(shù)問題和技術(shù)細(xì)節(jié):

PJIO:
  1. 在測試和開發(fā)過程中,通過查閱資料,發(fā)現(xiàn)c#和C++的數(shù)據(jù)存儲(chǔ)格式為小端類型而java是大端類型(即字節(jié)序問題)

在幾乎所有的機(jī)器上,多字節(jié)對象都被存儲(chǔ)為連續(xù)的字節(jié)序列。例如在C語言中,一個(gè)類型為int的變量x地址為0x100,那么其對應(yīng)地址表達(dá)式&x的值為0x100。且x的四個(gè)字節(jié)將被存儲(chǔ)在存儲(chǔ)器的0x100, 0x101, 0x102, 0x103位置。[1]
而存儲(chǔ)地址內(nèi)的排列則有兩個(gè)通用規(guī)則。一個(gè)多位的整數(shù)將按照其存儲(chǔ)地址的最低或最高字節(jié)排列。如果最低有效位在最高有效位的前面,則稱小端序;反之則稱大端序。在網(wǎng)絡(luò)應(yīng)用中,字節(jié)序是一個(gè)必須被考慮的因素,因?yàn)椴煌瑱C(jī)器類型可能采用不同標(biāo)準(zhǔn)的字節(jié)序,所以均按照網(wǎng)絡(luò)標(biāo)準(zhǔn)轉(zhuǎn)化。

網(wǎng)友評(píng)論