另一端是Java寫客戶端程序,兩者之間需要通信。
c++/c接收和發送的都是結構體,而Java是直接發送的字節流或者byte 數組。
解決方法:c++/c socket 在發送結構體的時候其實發送的也是字節流。因為結構體本身也是內存中的一塊連續數據。問題就變成了如何把結構體手動轉成字節的問題了
采用類似的報頭:
// packet head typedef struct tagPacketHead{ long PacketID; long PacketLen;}
PacketHead;此時套接口的讀寫方式為先讀報頭,在報頭中取出數據負載的長度,然后再讀相應字節的數據。
包頭后面跟上包體,其中包體的長度,就是上面結構體中的PacketLen,Clinet首先接受包頭,因為包頭是兩邊約定好的,所以可以直接Receive一個定長的消息,也就是這個包頭的長度的消息,從包頭中取得包體的長度后,就可以再次Receive一個包體長度的消息了。
那么Java中如何發送一個結構體呢?
下面是解決方法:
使用C/S模式,Client為VC6開發,Server為Java,通過Socket通信。
package org.charry.org; import java.net.*; /** * * 字節轉換,參考網絡文章 */ class Packet { private byte[] buf = null; /** * 將int轉為低字節在前,高字節在后的byte數組 */ 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轉為低字節在前,高字節在后的byte數組 */ private static byte[] toLH(float f) { return toLH(Float.floatToRawIntBits(f)); } /** * 構造並轉換 */ 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()); } /** * 返回要發送的數組 */ public byte[] getBuf() { return buf; } /** * 發送測試 */ 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(); } } }