TCP套接字通信核心要点

TCP套接字通信核心要点


通信模型架构

客户端-服务端模型

  • CS架构:客户端发起请求,服务端响应和处理请求
  • 双向通道:建立连接后实现全双工通信

服务端搭建流程

核心步骤

  1. 创建套接字

    复制代码
    int server = socket(AF_INET, SOCK_STREAM, 0);
    • 参数说明:AF_INET(IPv4)、SOCK_STREAM(TCP)、协议自动选择
  2. 绑定地址

    复制代码
    struct sockaddr_in addr = {
        .sin_family = AF_INET,
        .sin_port = htons(port),
        .sin_addr.s_addr = INADDR_ANY
    };
    bind(server, (struct sockaddr*)&addr, sizeof(addr));
    • 关键操作:字节序转换(htons)、IP绑定策略(INADDR_ANY
  3. 监听连接

    复制代码
    listen(server, 10); // 监听队列长度=10
  4. 接受连接

    复制代码
    int client = accept(server, (struct sockaddr*)&client_addr, &client_len);
    • 获取客户端地址:inet_ntop转换IP,ntohs转换端口
  5. 数据交互

    • 读取数据:read()recv()
    • 终止条件:返回值为0时表示客户端断开

客户端搭建流程

核心步骤

  1. 创建套接字

    复制代码
    int client = socket(AF_INET, SOCK_STREAM, 0);
  2. 设置服务端地址

    复制代码
    struct sockaddr_in addr = {
        .sin_family = AF_INET,
        .sin_port = htons(server_port),
        .sin_addr.s_addr = inet_addr("192.168.1.1")
    };
  3. 建立连接

    复制代码
    connect(client, (struct sockaddr*)&addr, sizeof(addr));
  4. 发送数据

    复制代码
    write(client, buffer, sizeof(buffer));

协议包设计

结构体定义

复制代码
typedef struct Pack {
    int packsize;    // 总字节数(含包头)
    char buf[4096];  // 数据缓冲区
    int used;        // 已使用字节数
} pack_t;

关键操作

  1. 数据封装

    复制代码
    void append(pack_t* pack, const char* str) {
        short len = strlen(str);
        *(short*)(pack->buf + pack->used) = len; // 写入长度
        memcpy(pack->buf + pack->used + 2, str, len); // 写入内容
        pack->used += (len + 2);
        pack->packsize = 4 + pack->used; // 更新总大小(含4字节包头)
    }
  2. 数据解析

    复制代码
    char** analysis(pack_t* pack) {
        char* buf = pack->buf;
        char** list = calloc(20, 8); // 存储解析后的字段
        int readed_size = 0;
        while (*(short*)(buf + readed_size) != 0) {
            short len = *(short*)(buf + readed_size);
            readed_size += 2;
            memcpy(temp, buf + readed_size, len);
            list[i++] = strdup(temp); // 动态分配存储
        }
        return list;
    }

关键问题处理

粘包与拆包

  • 粘包:多次发送的小数据包合并传输
  • 拆包:大数据包拆分发送(如超过1500字节限制)
  • 解决方案:协议包头声明数据长度,接收方按长度解析

连接管理

  • 服务端维护 :通过accept()返回的客户端描述符管理多个连接
  • 异常断开检测read()返回0时表示客户端主动关闭

代码实践要点

  • 错误处理 :检查socket()/bind()/listen()/connect()的返回值
  • 资源释放close()关闭套接字,free()释放动态内存
  • 字节序转换 :端口号使用htons/ntohs,IP使用inet_ntop/pton

总结:TCP套接字通信围绕地址绑定、连接管理、协议设计展开,需掌握服务端/客户端搭建流程、粘包处理及协议包解析方法,结合错误处理实现稳定通信。

相关推荐
冬天给予的预感33 分钟前
DAY 54 Inception网络及其思考
网络·python·深度学习
emplace_back8 小时前
C# 集合表达式和展开运算符 (..) 详解
开发语言·windows·c#
kfepiza9 小时前
Debian的`/etc/network/interfaces`的`allow-hotplug`和`auto`对比讲解 笔记250704
linux·服务器·网络·笔记·debian
无妄-20249 小时前
软件架构升级中的“隐形地雷”:版本选型与依赖链风险
java·服务器·网络·经验分享
群联云防护小杜10 小时前
构建分布式高防架构实现业务零中断
前端·网络·分布式·tcp/ip·安全·游戏·架构
一禅(OneZen)12 小时前
「Windows/Mac OS」AIGC图片生成视频 ,webui + stable-diffusion环境部署教程
windows·stable diffusion
AirDroid_cn12 小时前
OPPO手机怎样被其他手机远程控制?两台OPPO手机如何相互远程控制?
android·windows·ios·智能手机·iphone·远程工作·远程控制
岸边的风13 小时前
无需公网IP的文件交互:FileCodeBox容器化部署技术解析
网络·网络协议·tcp/ip
Zonda要好好学习14 小时前
Python入门Day4
java·网络·python
riverz122714 小时前
TCP backlog工作机制
服务器·网络·tcp/ip