Java向C++发送结构体
生活随笔
收集整理的這篇文章主要介紹了
Java向C++发送结构体
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
最近給個(gè)朋友做個(gè)網(wǎng)站的客戶端,使用C/S模式,Client為VC6開發(fā),Server為Java,通過Socket通信。由于Client這邊為C++,所以,在接受Java發(fā)過來的數(shù)據(jù)包時(shí),需要知道發(fā)來的包的長度,所以,就要引入變長包的機(jī)制。
方法是:首先Server發(fā)送一個(gè)包頭,如下:
// packet head
typedef struct tagPacketHead{
long PacketID;
long PacketLen;
}PacketHead;
包頭后面跟上包體,其中包體的長度,就是上面結(jié)構(gòu)體中的PacketLen,Clinet首先接受包頭,因?yàn)榘^是兩邊約定好的,所以可以直接Receive一個(gè)定長的消息,也就是這個(gè)包頭的長度的消息,從包頭中取得包體的長度后,就可以再次Receive一個(gè)包體長度的消息了。那么Java中如何發(fā)送一個(gè)結(jié)構(gòu)體呢?下面是解決方法:
package org.charry.org;import java.net.*;/** * * 字節(jié)轉(zhuǎn)換,參考網(wǎng)絡(luò)文章 */ class Packet { private byte[] buf = null;/** * 將int轉(zhuǎn)為低字節(jié)在前,高字節(jié)在后的byte數(shù)組 */ private static byte[] toLH(int n) { byte[] b = new byte[4]; b[0] = (byte) (n & 0xff); b[1] = (byte) (n >> 8 & 0xff); b[2] = (byte) (n >> 16 & 0xff); b[3] = (byte) (n >> 24 & 0xff); return b; }/** * 將float轉(zhuǎn)為低字節(jié)在前,高字節(jié)在后的byte數(shù)組 */ private static byte[] toLH(float f) { return toLH(Float.floatToRawIntBits(f)); }/** * 構(gòu)造并轉(zhuǎn)換 */ public Packet(int packetID, int packetLen, String packetBody) { byte[] temp = null;buf = new byte[packetBody.getBytes().length + 8]; temp = toLH(packetID); System.arraycopy(temp, 0, buf, 0, temp.length);temp = toLH(packetLen); System.arraycopy(temp, 0, buf, 4, temp.length);System.arraycopy(packetBody.getBytes(), 0, buf, 8, packetBody.length());}/** * 返回要發(fā)送的數(shù)組 */ public byte[] getBuf() { return buf; }/** * 發(fā)送測試 */ public static void main(String[] args) { try { String tmp = “test string!”; Socket sock = new Socket(”127.0.0.1″, 8888); sock.getOutputStream().write( new Packet(123, tmp.length(), tmp).getBuf()); sock.close(); } catch (Exception e) { e.printStackTrace(); } } }從Client端發(fā)到Server的數(shù)據(jù)就無須特殊處理了,Java的流可以很好的處理這些。
總結(jié)
以上是生活随笔為你收集整理的Java向C++发送结构体的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 理解有符号数和无符号数的区别
- 下一篇: java读取C++结构体,类型转换