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学习笔记,内容来源于极客时间《网络编程实战》

相关推荐
变身缎带1 小时前
Unity中的NetworkManager基于protobuf, Socket-TCP
tcp/ip·unity·游戏引擎
“αβ”1 小时前
MySQL表的操作
linux·网络·数据库·c++·网络协议·mysql·https
十五年专注C++开发2 小时前
Asio2: 一个基于 Boost.Asio 封装的高性能网络编程库
网络·c++·boost·asio·asio2
牛奶咖啡132 小时前
解决配置虚拟网络后同网段的设备网络不通问题
网络·桥接模式·主机模式·配置虚拟网络后同网段设备不通·排查解决同网段同网关网络不通·重置windows主机网络·nas模式
车载测试工程师3 小时前
CAPL学习-ETH功能函数-通用函数
网络·学习·tcp/ip·capl·canoe
ICT技术最前线3 小时前
sdwan组网软件如何帮助企业提升网络效率?
网络·sdwan·宽带组网
老蒋新思维4 小时前
创客匠人洞察:AI 时代 IP 变现的认知重构,从流量焦虑到价值深耕的破局之道
网络·人工智能·tcp/ip·重构·知识付费·创始人ip·创客匠人
Cher ~5 小时前
【协议】ICMP
网络·网络协议
丁丁丁梦涛6 小时前
EMQX配置 ssl 和 wss
网络·网络协议·ssl·emqx·wss
大熊背6 小时前
ISP基本框架及软硬件算法实现介绍目录
网络·接口隔离原则