gpt4 book ai didi

java - 处理 UDP 不可靠性

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

我正在 Java 中使用 DatagramPacket 和 DatagramSocket 类通过 UDP 发送消息。我对网络的了解并不完整。我知道:

  1. 当发送数据报时,它实际上可能被分割成多个数据 block ,在网络上独立传输(例如,如果我的数据报长度大于 MTU)。

  2. UDP 不保证消息接收时的顺序(并且根本不保证消息的接收)。

将这些信息放在一起,我“理解”如果我发送一个(大)DatagramPacket,我可能会以任何顺序收到数据报的字节(有些部分甚至可能会丢失)!但我认为我误解了一些东西,因为如果是这样的话,没有人会使用这样的协议(protocol)。

如何确保我收到的数据报(如果我收到)等于我发送的数据报?

最佳答案

你的理解是错误的。如果您的数据报在发送端被 IP(UDP 层以下)分成片段,则接收方的 IP 将以正确的顺序重新组装这些片段,然后将整个重新组装的数据报传递到接收方的 UDP 层。如果数据报的任何片段丢失,则重组将失败,部分重建的数据报将被丢弃,并且任何内容都不会传递到接收方的 UDP 层。因此,接收 UDP(以及接收应用程序)要么得到完整的数据报,要么什么也得不到。它永远不会得到部分数据报,也永远不会得到内容因碎片而被打乱的数据报。

如果传入数据报大于应用程序的接收缓冲区,则可以向接收应用程序提供部分(截断)数据报,但这与碎片无关。

关于java - 处理 UDP 不可靠性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49679852/

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