我写了一个一般的socket的例程,每次sender会取1024*32 bytes的数据发送过去。receiver 却每次只能接受4380 bytes 从inputstream里面。请问怎么才能让receiver每次也接收到1024×32这么多数据呢?我试过了socket.setReceiveSize()不管用。

解决方案 »

  1.   

    贴一下代码啊,是不是没有flush()
      

  2.   

    不是,问题就在这里了,sender每次发送了1024*32数据,receiver每次接受只有4380,但是receiver没有丢包,而是好像把包拆成了好几个小包,我想问问socket有没有这样的机制可以拆包的。(我知道CS里按着‘E’就能拆包了,各位就不用告诉我这个答案了)
      

  3.   

    其实这个问题真的值得讨论的,应该是网络问题,但是后面就涉及到了java的网络解决方案,看来各位对这样的话题没什么兴趣。
      

  4.   

    Windows的socket缓冲区总共才1024 × 8 吧,
    你的sender怎么一次性发出去1024 × 32的?
    应该是你每次发的太多,所以自动分包了,分出来的包就出来4380了。而不是缓冲了1024 × 32,然后一次发出去这么多。