gpt4 book ai didi

java - 缓冲字节数组(来自 DatagramPacket)

转载 作者:行者123 更新时间:2023-12-02 05:15:58 25 4
gpt4 key购买 nike

因此,在寻找合适的库后,我决定创建自己的库,这是其中的一部分。

try {
DatagramSocket serverSocket = new DatagramSocket(client_port);
byte[] receiveData = new byte[1024];
byte[] finalData;
while (true) {
DatagramPacket receivePacket = new DatagramPacket(receiveData, receiveData.length);
erverSocket.receive(receivePacket);
if (this.address == receivePacket.getAddress() && this.server_port == receivePacket.getPort()) {
** handler.onMessage(receivePacket.getData()); **
}
}
} catch (IOException ex) {
Logger.getLogger(PacketHandler.class.getName()).log(Level.SEVERE, null, ex);

这段代码显然是异步运行的。

receiveData设置为1024,这是非常浪费的。这也意味着任何大于 1024 的内容都会被分成两个或多个由库触发的“事件”。

我想知道如何制作缓冲区,因为我已经完全空白了。本质上,您必须以某种方式计算字节数并将其插入一个新数组中。

所以我基本上是在要求一种有效的方法,它不必包含代码。

最佳答案

您确定需要使用 UDP 吗?看来你应该将其更改为 TCP 实现。你想使用netty吗?请参阅here

1024 字节是 UDP datagaram 的正常安全值,使其更大可能会给路由器带来问题。 (参见https://stackoverflow.com/a/13089776/3502543)。

如果你不想使用netty,你应该提供类似DelimiterBasedFrameDecoder的东西。

已编辑。

关于java - 缓冲字节数组(来自 DatagramPacket),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26950236/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com