如何解决为什么 TCP 不告诉我收到了多少字节?
在 TCP 连接上发送数据时,TCP 堆栈确保字节到达,并根据需要重新发送丢失的数据包。为此,另一端发送 ACK 消息以确认它已收到数据。
当 TCP 栈收到 ACK 消息时,它知道另一端已经收到了一些数据,可以停止重传。虽然它并不确切知道另一端收到了多少数据(ACK 可能会丢失或延迟),但它至少有一个已在另一端收到的数据的下限。
据我所知,TCP 实现不会向高级调用者提供这些信息。
具体来说,我正在考虑 POSIX 套接字 API,据我所知,无法判断另一端收到了多少数据。我只知道我发送了多少,但由于缓冲区很大,可能需要很长时间才能接收到这些数据。
显然,如果我控制另一端,我可以偶尔用显式消息(在同一个 tcp 连接上或通过单独的通道)报告收到了多少数据,但这似乎不雅。
为什么不向用户公开这些信息?这对进度条之类的东西很有用。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。