分包与粘包

一 TCP粘包和分包概念

**粘包:**tcp接收到数据之后,有序放在接收缓冲区中,数据之间不存在分隔符的说法,如果接收方没有及时的从缓冲区中取走数据看上去就象粘在了一起。

**分包:**tcp报文的大小缺省是1460 字节,如果发送缓冲区中的数据超过1460字节,tcp将拆分成多个包发送,如果接收方及时的从接收缓冲区中取走了数据,看上去像就接收到了多个报文。

二 粘包和分包解决方法

  • 采用固定长度的报文。即发送端固定发送30B,接收端固定接收30B,就不会粘包和分包。

  • 在报文前面加上报文长度。 报文头部(4字节的整数)+报文内容。

  • 报文之间用分隔符。http协议\r\n\r\n。

三 解决粘包和分包的代码示例

采用方法二,即:在报文前面加上报文长度。 报文头部(4字节的整数)+报文内容。

发送端:

cpp 复制代码
        memset(buf,0,sizeof(buf));
        sprintf(buf,"这是第%d个报文。",ii);
        int len = strlen(buf);
        char tmp[1024];
        memset(tmp,0,sizeof(tmp));
        memcpy(tmp,&len,4);		//前四个字节存放报文长度
        memcpy(tmp+4,buf,strlen(buf));	//后四个字节存放保温内容
        if (send(sockfd,tmp,len+4,0) <=0)       // 把命令行输入的内容发送给服务端。
        { 
            printf("write() failed.\n");  close(sockfd);  return -1;
        }

接收端:

cpp 复制代码
		bzero(&buffer, sizeof(buffer));
        int len;
        ssize_t nread = read(evs[ii].data.fd, &len, 4);    // 这行代码用了read(),也可以用recv(),一样的,不要纠结。
        if (nread > 0)      // 成功的读取到了数据。
        {
            bzero(&buffer, sizeof(buffer));
            nread = read(evs[ii].data.fd,buffer,len);
            printf("len=%d,%s\n",len,buffer);	//%d输出len中内容。
        } 
相关推荐
神鸟云38 分钟前
DELL服务器 R系列 IPMI的配置
linux·运维·服务器·网络·边缘计算·pcdn
herderl1 小时前
**僵尸进程(Zombie Process)** 和**孤儿进程(Orphan Process)**
linux·运维·服务器·网络·网络协议
亲爱的非洲野猪1 小时前
令牌桶(Token Bucket)和漏桶(Leaky Bucket)细节对比
网络·算法·限流·服务
G_H_S_3_2 小时前
【网络运维】Playbook项目实战:基于 Ansible Playbook 一键部署 LNMP 架构服务器
linux·运维·服务器·网络·ansible
XINVRY-FPGA2 小时前
10CL016YF484C8G Altera FPGA Cyclone
嵌入式硬件·网络协议·fpga开发·云计算·硬件工程·信息与通信·fpga
七七&55611 小时前
2024年08月13日 Go生态洞察:Go 1.23 发布与全面深度解读
开发语言·网络·golang
元清加油12 小时前
【Golang】:函数和包
服务器·开发语言·网络·后端·网络协议·golang
向日葵.14 小时前
fastdds.ignore_local_endpoints 属性
服务器·网络·php
athink_cn16 小时前
HTTP/2新型漏洞“MadeYouReset“曝光:可发动大规模DoS攻击
网络·网络协议·安全·http·网络安全
zzc92116 小时前
TLSv1.2协议与TCP/UDP协议传输数据内容差异
网络·测试工具·安全·wireshark·ssl·密钥·tlsv1.2