TCP与UDP传输的学习

void *memset(void *s, int c, size_t n);

功能:将一块内存空间的每个字节都设置为指定的值;这个函数通常用于初始化一个内存空间,或者清空一个空间;

参数:viod * s 空类型指针,指向要填充内存块;(空间/内存的起点);

Int c 填充空间的值;通常为无符号字符;(空间/内存中填充的值是什么);

Size_t n 表示要填充的字节数(字节长度);

返回值:返回这块填充空间的起始地址;

粘包问题:

粘包(Packet Splitting or Message Smuggling)是指在网络通信中,当发送的数据包大小超过接收端设定的最大长度限制时,可能会将大数据包分割成几个小包发送。接收端收到这些小包后,由于它们各自独立,如果不按照原来的顺序重组,就可能导致数据解析错误,形成乱序或者丢失部分信息。

Tcp流式套接字;数据与数据之间没有边界,导致可能多次的数据粘到一起;

例如,在TCP协议中,如果POST请求体过大,服务器可能设置了一个固定大小的缓冲区来接收数据。若一次性发送的数据超过了这个缓冲区大小,就会发生粘包现象,导致后续的小包被视为新的请求,造成数据混淆。

为了避免粘包问题,通常的做法有:

  1. 规定一些数据与数据之间的间隔符;(如:"\aa" "\r\n");
  2. 可以指定要发送的数据的长度;
  3. 或者将数据打包来避免粘包问题;
  4. 数据分块:预先确定好每个数据包的大小,并添加边界标识,如消息头信息中包含总数据长度;
  5. 使用适当的序列号或确认机制:如TCP协议的确认应答,保证数据包按顺序到达;
  6. 使用持久连接(Keep-Alive)或长轮询/WebSockets等技术,保持连接打开,直到所有数据都已发送完毕

ssize_t recv(int sockfd, void *buf, size_t len, int flags);

相当于文件操作中的read;

参数:int flags 非阻塞方式:默认接收方式为0;

阻塞方式:MSG_DONTSAIT

ssize_t send(int sockfd, const void *buf, size_t len, int flags)

相当于文件操作中的write;

参数:int flags 非阻塞方式:默认接收方式为0;

阻塞方式:MSG_DONTSAIT

总结:TCP 和 UDP的协议特点

|---------|--------|
| TCP | UDP |
| 1.面向连接; | 1.无连接; |
| 2.可靠传输; | 2.不可靠; |
| 3.字节流; | 3.数据包; |

网络测试常用工具

关于TCP和UDP协议的形式

相关推荐
ErizJ2 分钟前
CN|腾讯面经总结
网络·计算机网络·面试
X7x54 分钟前
广域网技术全解:从 CE/PE/P 设备到 PPP/PPPoE 协议与三厂商配置实战
网络·网络协议·信息与通信·广域网技术
jimy18 分钟前
Oracle的VM.Standard.E2.1.Micro虚拟机创建后,必要的安全设置,卸snap省内存
服务器·安全
songx_999 分钟前
Linux基础3
linux·运维·服务器
半壶清水10 分钟前
windows环境下,bmv2虚拟交换机的部署与使用方法
网络·windows·python·网络协议
TechWayfarer11 分钟前
营销数据分析:如何利用IP归属地识别和规避虚假流量
网络·数据库·python·tcp/ip·数据分析
拾光Ծ16 分钟前
【Linux系统】进程信号(下):信号处理与“操作系统运行原理”
linux·运维·服务器·信号处理·操作系统原理
Cat_Rocky16 分钟前
ingress service配置解析
linux·服务器·网络
小冷爱学习!16 分钟前
Apache Shiro 1.2.4 反序列化漏洞Shiro-550(CVE-2016-4437)
服务器·网络·python·安全·网络安全·apache
|_⊙19 分钟前
Linux 进程知识扩展(下)
linux·运维·服务器