TCP数据流的概念

发送端TCP数据流

考虑到实际网络中的各种影响,那么其实发送端调用send函数发送两个字符串hello, messagewelcome的实际TCP分组可能有很多种。

第一种情况:一个TCP分组发出去

hello, messagewelcome在一个TCP分组中发送出去,比如:

复制代码
*************hello, messagewelcome*******************

第二种情况:前一个字符串一部分放到另一个TCP分组接着发送

比如(可以列举很多种):

其中一个分组是:

复制代码
*********************************hello, m

另一个分组是:

复制代码
essagewelcome******************************

第三种情况:后一个字符串一部分放到前一个TCP分组发送

比如(可以列举很多种):

其中一个分组是:

shell 复制代码
*********************************hello, messagew

另一个分组是:

shell 复制代码
elcome******************************

上边这三种情况可以有很多组合,这里想要表达的意思就是我们不能假设整个数据就在一个TCP分组里边发送出去,也就是说,不能假设"数据流和 TCP 分组是一种映射关系"。

接收端TCP数据流

不管发送端数据分了多少个TCP分组发来,那么最后接受端接受到的数据都是:

shell 复制代码
*****************hello, messagewelcome*************

1.先调用send函数发送的数据一定会比后调用send函数发送的数据先到,这就是一个由TCP保证的。

2.如果发送过程中有 TCP 分组丢失,但是其后续分组陆续到达,那么 TCP 协议栈会缓存后续分组,直到前面丢失的分组到达,最终,形成可以被应用程序读取的数据流。

此文章为11月Day 29学习笔记,内容来源于极客时间《网络编程实战》

相关推荐
硬汉嵌入式5 分钟前
Microchip开源的自家网络协议栈确实不错,功能完善,并且支持图形化一键配置
网络协议
沐芊屿21 分钟前
华为交换机配置M-LAG
服务器·网络·华为
会员源码网22 分钟前
交易所源码搭建全教程
网络
枷锁—sha25 分钟前
【SRC】越权漏洞检测
运维·服务器·网络·安全·网络安全·系统安全
qqssss121dfd1 小时前
STM32H750XBH6的ETH模块移植LWIP
网络·stm32·嵌入式硬件
酣大智1 小时前
参考模型--物理层
网络
B2_Proxy2 小时前
IP 来源合规性,正在成为全球业务的隐性门槛
网络·爬虫·网络协议·安全
MMME~3 小时前
Ansible Playbook高效自动化实战指南
网络·自动化·ansible
数据安全科普王3 小时前
从 HTTP/1.1 到 HTTP/3:协议演进如何改变 Web 性能?
网络·其他
舰长1153 小时前
linux 实现文件共享的实现方式比较
linux·服务器·网络