网络编程客户端和服务端连接流程

复制代码
服务器端:

socket()-->bind( )-->listen()-->accept()-->read()/write()--->close()

socket()//创建套接字
bind()//命名socket,分配套接字地址
listen()//监听状态,等待连接请求状态
accept()//允许连接(被动连接)
read()/write()或者send()/recv() //进行数据交换
close()//断开连接

客户端: 

socket()-->connect()-->read()/write()-->close()

socket()//创建套接字
connect()//请求连接
read()/write() send()/recv()//进行数据交换
close()//断开连接

对于服务端,创建socket后需要分配其地址,调用bind函数

XML 复制代码
#include <sys/types.h> 					
#include <sys/socket.h>
bind(socket,(struct sockaddr*)addr,socklen_t addrlen)
//该函数参数为需要命名的socket,socket地址和该地址的长度。addr的IP为自己主机的IP地址

//返回值  成功0
          失败 -1并设置erron

而对于客户端,socket地址是匿名分配的,不需要自己来分配,只需要用connect函数来请求连接,该连接为主动连接。

XML 复制代码
#include <sys/types.h> 					
#include <sys/socket.h>
int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);

参数:
第一个参数:int sockdf:
		    socket文件描述符
第二个参数: const struct sockaddr *addr:
			传入参数,指定服务器端地址信息,含IP地址和端口号
第三个参数:socklen_t addrlen:
			传入参数,传入sizeof(addr)大小
返回值:
	成功: 0
	失败:-1,设置errno

客户端发送connect()连接请求后,并不意味着服务端执行accept后才接收连接,因此connect()返回后不代表进行数据交换。客户端的连接请求首先会存放到listne创建的监听队列中,而accept只是从监听队列中取出连接,不关心连接处于何种状态(比如ESTABLISHED和CLOSE_WAIT),更不关心网络状态的变化。

XML 复制代码
#include<sys/socket.h>
int listen(int sockfd,int backlog);

//参数1: 表示进入监听的命名后的socket
//参数2: 表示内核监听队列最大长度,linux2.2后表示完全连接状态的最大上限

//返回:
// 成功:0
// 失败:-1 设置erron
XML 复制代码
#include<sys/types.h>
#include<sys/socket.h>
int accept(int sockfd,struct sockaddr*addr,socklen_t*addrlen);

//参数1: 执行过listen系统调用的监听socket

//参数2 :客户端的socket地址(自动分配)

//参数3: 客户端的socket地址长度

//返回值  
// 成功: 0
//失败 : -1 设置erron
相关推荐
TG_yunshuguoji9 小时前
阿里云代理商: 阿里云部署OpenClaw 个性化配置指南 3 大场景模板详解
服务器·阿里云·云计算·openclaw
SeanDe9 小时前
Linux grep 命令用法详解
linux·服务器·网络
W.W.H.9 小时前
Linux共享文件夹不显示,每次都要重新加载问题解决
linux·运维·服务器
2401_8357925410 小时前
Linux复习笔记
linux·服务器·笔记
s090713610 小时前
ZYNQ无SD卡纯NAND Flash启动Linux全攻略
linux·fpga开发·zynq·nand flash启动
ChengQianO10 小时前
ROS2 导航播报 & 轨迹模拟 —— 计划
linux·ubuntu·ros
志栋智能10 小时前
告别高昂投入:超自动化IT运维的轻量化实践
大数据·运维·网络·人工智能·自动化
扛枪的书生11 小时前
Jenkins 学习总结
linux
strive programming11 小时前
Linux从入门到精通——基础IO(简洁清晰版)
linux·运维·服务器