編輯:關於Android編程
ava:采用大端字節序存儲數據【低地址存放數據的高位,高地址存放數據的低位,數據高位存放在數組的前面】
windows(intel平台):采用小端字節序存儲數據【低地址存放數據的低位,高地址存放數據的高位,數據的高位存放在數組的後面】(windows接收java發送過來的short,int需要調用ntohs和ntohl來轉換到小數端)
【數據高位】:0x1234的高位為 0x12
【數據低位】:0x1234的低位為 0x34
如: int ihex = 0x12345678;
short shex=0x1234;
java內存中存儲為:
byte[] = { '0x12','0x34','0x56','0x78'} byte[] = { '0x12','0x34'}
而windows下(intel cpu):
c/c++/qt 存儲為
一個字符數組地址是從首地址開始遞增的,也就是數組下標越大,內存地址越大。
=====char[] 前面是低地址,後面是高地址
char [] = {'0x78','0x56','0x34','0x12'} //QByteArray和char[]一致 char [] = {'0x34','0x12'}
設計java端client程序時,需要我們在程序中顯式采用大端字節序來處理int,short,long(字符串不需要考慮),即將int,short,long轉換成byte[]。【將short,int的高位存儲在字符數組的前面】當然你想用小字節存放也可以,socket收到數據後打印出來看int,short的16進制數字節序,然後做處理即可。
函數如下:(大端字節序存儲的函數)
/*整型轉化成字符序列,類似的函數baidu可以找到很多
*執行位操作,將int i = 0x12345678; 對應二進制:
*內存中存放:低地址
*00010010 0x12
*00110100 0x34
*01010110 0x56
*01111000 0x78
*高地址
*/
// 存放到byte[]={'0x12','0x34','0x56','0x78'}位置處
public static byte[] intToBytes(int i) { //bytes[0] = 00010010 //bytes[1] = 00110100 //bytes[2] = 01010110 //bytes[3] = 01111000 byte bytes[] = new byte[4]; for (int j = 3; j >= 0; j--) bytes[3 - j] = (byte)(i >> 8 * (3 - j) & 0xff); //bytes[0] :直接將i的低8bits和0xff與操作即可,此時j=3 return bytes; }
public static byte[] shortToBytes(short s) { byte bytes[] = new byte[2]; bytes[0]=(byte)(0xFF&(s>>8)); //低地址存放高位數據,低位數據被右移8bits後刪除了。(返回高8位值) bytes[1]=(byte)(0xFF&s); //高地址存放低位數據,位操作當然是低位執行的與操作。當前只和8bits與,(即返回低8bits值) return bytes; }
以上就是對android java 和 windows C/C++/QT通訊時 數據存放字節序的理解,有需要的可以參考下
什麼是反射?反射是一種能夠在程序運行時動態訪問、修改某個類中任意屬性(狀態)和方法(行為)的機制(包括private實例和方法),java反射機制提供了以下幾個功能:在運
本系列文章提供簡單Android應用開發實例方法,文章步驟如下所示:1 獲取應用所需的數據源數據源一般來源於互聯網、個人搜集或者其他方式2 應用UI設計每個應用軟件都需要
Android 調試工具,這裡做一個總結整理。DDMS -- Dalvik debug monitor service &n
先上圖 LEDView效果如圖所示。 之前看到一篇博客使用兩個TextView實現了該效果,於是我想用自定義控件的方式實現一個LEDView,使用時即可直接使用該控件。