当前位置: 首页 > java >正文

嵌入式第三十六天(网络编程(TCP))

一.TCP

1.

2.

TCP(传输控制协议)通过“三次握手”建立连接,通过“四次挥手”终止连接,以此保证数据传输的可靠性。

一、三次握手(建立连接)

目的是确认双方的发送和接收能力正常,并协商初始序列号。
过程如下:

1. 客户端→服务器(SYN=1,seq=x):客户端发送连接请求报文,标记SYN为1(请求同步),随机生成初始序列号x。此时客户端进入“SYN-SENT”状态。
2. 服务器→客户端(SYN=1,ACK=1,seq=y,ack=x+1):服务器收到请求后,同意连接,回复报文:
- SYN=1(表示服务器也发起同步),生成自己的初始序列号y;
- ACK=1(确认收到客户端请求),ack=x+1(表示期望接收客户端下一个序列号为x+1的数据)。
此时服务器进入“SYN-RCVD”状态。
3. 客户端→服务器(ACK=1,seq=x+1,ack=y+1):客户端收到服务器回复后,再次发送确认报文:
- ACK=1(确认收到服务器的同步请求);
- seq=x+1(基于自己的初始序列号递增);
- ack=y+1(表示期望接收服务器下一个序列号为y+1的数据)。
双方收到后均进入“ESTABLISHED”状态,连接建立完成。



二、四次挥手(终止连接)

目的是确保双方都已完成数据传输,安全关闭连接(因TCP是全双工通信,需双向关闭)。
过程如下:

1. 客户端→服务器(FIN=1,seq=u):客户端数据发送完毕,发送终止连接请求(FIN=1),序列号为u。客户端进入“FIN-WAIT-1”状态。
2. 服务器→客户端(ACK=1,seq=v,ack=u+1):服务器收到FIN后,先回复确认报文(ACK=1),ack=u+1(确认收到客户端的终止请求),序列号为v。此时服务器进入“CLOSE-WAIT”状态,客户端收到后进入“FIN-WAIT-2”状态(等待服务器的FIN)。
(注:此时服务器可能仍有数据未发送完,会继续向客户端传输数据)
3. 服务器→客户端(FIN=1,ACK=1,seq=w,ack=u+1):服务器数据发送完毕后,发送自己的终止请求(FIN=1),同时再次确认ack=u+1,序列号为w。服务器进入“LAST-ACK”状态。
4. 客户端→服务器(ACK=1,seq=u+1,ack=w+1):客户端收到服务器的FIN后,回复确认报文(ACK=1),ack=w+1(确认收到服务器的终止请求),序列号为u+1。客户端进入“TIME-WAIT”状态(等待2MSL时间,确保服务器收到确认后再关闭),服务器收到后进入“CLOSED”状态。
客户端等待2MSL后,也进入“CLOSED”状态,连接彻底关闭。

关键区别:

- 三次握手:第三次握手是客户端对服务器“SYN+ACK”的确认,避免“已失效的连接请求报文”被服务器误接收后建立无效连接。
- 四次挥手:因服务器收到客户端FIN后,可能仍有数据需传输,无法同时发送FIN和ACK(需先确认接收,再发终止请求),因此比握手多一次交互。

三.TCP编程流程

四.相关函数接口

示例:

#include "head.h"int main(int argc,const char argv[])
{int client_socket;struct sockaddr_in seraddr;char buff[1024] = {0};client_socket = socket(AF_INET,SOCK_STREAM,0);if(client_socket < 0){perror("socket error");return -1;}seraddr.sin_family = AF_INET;seraddr.sin_port = htons(50000);seraddr.sin_addr.s_addr  = inet_addr("192.168.19.129");int ret = connect(client_socket,(struct sockaddr*)&seraddr,sizeof(seraddr));if(ret < 0){perror("connect error");return -1;}while(1){printf("B> ");fgets(buff,sizeof(buff),stdin);send(client_socket,buff,strlen(buff),0);memset(buff,0,sizeof(buff));ssize_t cnt = recv(client_socket,buff,sizeof(buff),0);if(cnt <= 0){perror("recv perror");return -1;}printf("A> %s\n",buff);}close(client_socket);return 0;
}
#include "head.h"int main(int argc,const char *argv[])
{int server_socket;int client_socket;struct sockaddr_in server_addr;struct sockaddr_in client_addr;socklen_t client_addr_len = sizeof(client_addr);char buff[1024];server_socket = socket(AF_INET, SOCK_STREAM, 0);if (server_socket < 0){perror("socket error");return -1;}server_addr.sin_family = AF_INET;server_addr.sin_port = htons(50000);server_addr.sin_addr.s_addr = inet_addr("192.168.19.129");int ret = bind(server_socket, (struct sockaddr*)&server_addr, sizeof(server_addr));if(ret < 0){perror("bind error");return -1;}if (listen(server_socket, 5) < 0){perror("listen error");return -1;}client_socket = accept(server_socket, (struct sockaddr*)&client_addr, &client_addr_len);if (client_socket < 0){perror("accept error");return -1;}while (1){memset(buff,0,sizeof(buff));ssize_t cnt = recv(client_socket,buff,sizeof(buff),0);if (cnt <= 0){perror("recv error");break;}printf("B> %s\n", buff);printf("A> ");fgets(buff,sizeof(buff),stdin);send(client_socket,buff,strlen(buff),0);}close(client_socket);close(server_socket);return 0;
}

五.相关问题

http://www.xdnf.cn/news/18733.html

相关文章:

  • Java的数字计算
  • More Effective C++ 条款06: 区分自增自减操作符的前缀和后缀形式
  • 若依4.7.8(springboot2.5.15)升级到4.8.1(springboot3.3.5)并集成Dubbo3客户端
  • 工程师的自我修养
  • Python JSON数据格式
  • 【数据结构】-4-顺序表(上)
  • 复杂水域场景识别率↑89%!陌讯多模态融合算法在岸边垃圾检测的落地实践
  • CUDA安装,pytorch库安装
  • 小米AX3600访问桥接的光猫
  • 图解SpringMVC工作流程,以及源码分析。
  • Hibernate详解
  • 爆肝三周,我终于上线了自己的第一个小程序
  • Vue 项目 package.json 终极详解(主流实践 / 逐项说明)
  • 大型 C/C++ 项目中 AI 助手(Cursor / Claude Code)日常操作清单与发散思路
  • 详解triton.jit及PTX
  • 微服务-19.什么是网关
  • AI重塑跨境电商:选品成功率提升53%+物流效率加快34%,多语种运营成破局关键
  • 试析微剧《云端爱人》:AI时代的数字爱情寓言与情感觉醒
  • AI Agent与生成式AI双驱动:AI如何重塑商业格局并创造千亿级增量价值
  • Node【文件+模块化+对象】详讲:
  • 如何根据NTP协议报文的第一个字节来判断协议版本和处理模式?
  • 【CV】OpenCV①——OpenCV常用模块
  • 数学建模-线性规划(LP)
  • HbuilderX下载与安装
  • MATLAB GUI 设计入门:用 Guide 工具快速搭建交互界面
  • (LeetCode 每日一题) 1493. 删掉一个元素以后全为 1 的最长子数组 (双指针)
  • rust语言 (1.88) egui (0.32.1) 学习笔记(逐行注释)(十八) 使用表格
  • 【分布式中间件】Kafka 核心配置深度解析与优化指南
  • 【数据结构与算法】并查集
  • 当GitHub“断网”:从应急到终极方案,手把手搭建永不宕机的代码协作体系