ノードがUDPパケットで通信するp2pアプリケーションを実装しています。InputStream から読み取られたパケットが不完全な場合があります。
これが私のコードです:
...
protected String key;
    protected Identifier messId; //Identifier hold a BigInteger
    protected String range;
    protected String concat;
....
public ReplicationMessage(DataInput in) throws IOException {
       fromStream(in);
}
public void fromStream(DataInput in)
    try {
    super.fromStream(in);      
    int length=in.readInt();
    byte[] data=new byte[length];
    in.readFully(data);
    concat = new String(data);
    System.out.println("concat: "+concat); 
            messId = new Identifier(in);
    } catch (IOException e) {
        e.printStackTrace();
    }        
  }
public void toStream(DataOutput out) {
    try {
    super.toStream(out);
    byte[] data = concat.getBytes();
    out.writeInt(data.length);
    out.write(data);        
    messId.toStream(out);
    } catch (IOException e) {
e.printStackTrace();
    }   
}
たとえば、読み取りパケットはいつか完了します。
連結: 179136678282544:140737488355328
ただし、たとえば完全ではない場合もあります
連結: 179136678282544 連結: 179136678282544 連結: 179136678282544
誰でも問題が何であるか教えてもらえますか?
どうもありがとう
送信用の UDP パケットを送受信するためのコードは次のとおりです。
private void sendMessage(int comm, Message message, InetAddress ip, int port) throws IOException {
    ByteArrayOutputStream bout = new ByteArrayOutputStream();
    DataOutputStream dout = new DataOutputStream(bout);
    dout.writeInt(comm);
    dout.writeByte(message.code());
    message.toStream(dout);
    dout.close();
    byte[] data = bout.toByteArray();
    if (data.length > DATAGRAM_BUFFER_SIZE) {
        throw new IOException("Message too big, size="+data.length+
                              " bytes, max="+DATAGRAM_BUFFER_SIZE+" bytes");
    }
    DatagramPacket packet = new DatagramPacket(data, data.length, ip, port);
    socket.send(packet);
}
UDPパケットの受信用
     byte[] buffer = new byte[DATAGRAM_BUFFER_SIZE];
     DatagramPacket packet = new DatagramPacket(buffer, buffer.length);
     socket.receive(packet);
1 台のマシンに属する送信ノードと受信ノード。バッファ受信パケットは、パケット長よりもはるかに大きい 10*1024 バイトに設定されます。
着信データパケットをストリームに変換するコードは次のとおりです
                ByteArrayInputStream bin = new ByteArrayInputStream(packet.getData(),
                                             packet.getOffset(), packet.getLength());
                DataInputStream din = new DataInputStream(bin);
                int comm = din.readInt();
                byte messCode = din.readByte();
                Message message = factory.createMessage(messCode, din);