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协议的形式

相关推荐
折翅鵬1 小时前
Android史诗级网络优化实践总结
android·网络
网安小白的进阶之路4 小时前
B模块 安全通信网络 第二门课IPv6与WLAN 01
网络·安全
学习3人组5 小时前
Cisco ASA防火墙 NAT实验:源NAT+目的NAT(Trust/Untrust双区域,无DMZ)
网络·网络安全
广州灵眸科技有限公司5 小时前
瑞芯微RV1126B开发板(EASY-EAI-PI2) Linux虚拟机准备
linux·运维·服务器
天天进步20155 小时前
Tunnelto 源码解析 #6:数据转发核心:远端 HTTP 请求如何被转发到本地 localhost
网络
Lana学习中6 小时前
【运维杂记】连接不上远程服务器的问题处理
运维·服务器
189228048616 小时前
NV023固态MT29F16T08GWLCEJ9-QBES:C
大数据·服务器·人工智能·科技·缓存
志栋智能6 小时前
安全超自动化:应对海量安全警报的唯一解
网络·安全·自动化
dxxt_yy7 小时前
鼎讯信通 HD‑095B:能源行业高精度频谱测试解析
网络·能源
LZZ and MYY8 小时前
RTS 在windows和Linux之间ShareMem
linux·运维·服务器