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

相关推荐
LuLaLuLaLeLLLLLL33 分钟前
RPC 框架学习笔记
网络·网络协议·rpc
冰橙子id1 小时前
linux-远程访问管理(sshd,scp,sftp)
linux·网络·ssh
橘子在努力4 小时前
【橘子分布式】Thrift RPC(理论篇)
分布式·网络协议·rpc
liulilittle5 小时前
.NET ExpandoObject 技术原理解析
开发语言·网络·windows·c#·.net·net·动态编程
委婉待续6 小时前
计算机网络通信的相关知识总结
开发语言·网络
不超限6 小时前
IIS错误:Service Unavailable HTTP Error 503. The service is unavailable.
网络·网络协议·http
.YYY8 小时前
网络--静态路由综合实验
网络·计算机网络
CZZDg8 小时前
Redis Sentinel哨兵集群
java·网络·数据库
tan77º8 小时前
【Linux网络编程】应用层自定义协议与序列化
linux·运维·服务器·网络·c++·tcp/ip
wanhengidc8 小时前
在徐州网络中服务器租用与托管的优势
运维·服务器·网络