Server 端
-------------------------- 初始化部分 -------------------------------
1.创建监听套接字: 使用socket(协议家族,套接字的类型,0)
套接字类型有 SOCK_STREAM:表示面向连接的套接字(Tcp协议);
SOCK_DGRAM:表示无连接的数据报套接字(Udp协议);
当指定具体使用的协议之后,第三个参数一般传0.
**2.保存套接字地址:**一般IPV4协议类型使用的是struct sockaddr_in套接字地址类型
struct sockaddr_in
{
sin_family; // 保存协议类型
sin_port; // 保存端口号 (一般从外部传进来) 注意要转成网络字节序
sin_addr; // 保存要绑定的ip地址 (0.0.0.0可以响应其他主机连接任意本地ip)
// 注意要字符串转点分式十进制整数类型且要保证网络字节序
}
**3.将套接字地址绑定到套接字:**bind(_listenfd, (const struct sockaddr*), socklen_t);
**4.监听套接字:**listen(sockfd, backlog);
-------------------------- 运行部分 -----------------------------------
5.创建套接字地址(用于保存客户端套接字地址);
6.从监听套接字上接收客户端的连接请求;int sockfd = accept(_listenfd, ...);
7.进行通信!!! TCP协议可以直接使用write和read系统调用实现跨网络的进程间通信
Client 端
-------------------------- 初始化部分 -------------------------------
1.需要从外部传入server的ip和端口号
2.创建套接字; client不需要为自己的套接字显示绑定套接字地址,而是由操作系统在请求连接的时候默认分配;
3.解析外部传入的server套接字地址并保存到栈区
4.请求连接: connect(sockfd, (const struct sockaddr*), socklen_t );
5.进行通信!!! TCP协议可以直接使用write和read系统调用实现跨网络的进程间通信
Tcp 通信简单demo思路
疯狂的代M夫2025-05-09 17:30
相关推荐
寻星探路6 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑王达舒19946 小时前
HTTP vs HTTPS: 终极解析,保护你的数据究竟有多重要?朱皮皮呀6 小时前
HTTPS的工作过程Binary-Jeff6 小时前
一文读懂 HTTPS 协议及其工作流程盟接之桥9 小时前
盟接之桥说制造:引流品 × 利润品,全球电商平台高效产品组合策略(供讨论)会员源码网10 小时前
理财源码开发:单语言深耕还是多语言融合?看完这篇不踩坑米羊12111 小时前
已有安全措施确认(上)ManThink Technology12 小时前
如何使用EBHelper 简化EdgeBus的代码编写?珠海西格电力科技12 小时前
微电网能量平衡理论的实现条件在不同场景下有哪些差异?QT.qtqtqtqtqt12 小时前
未授权访问漏洞