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

复制代码
服务器端:

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
相关推荐
咩咩大主教几秒前
VSCode远程连接Linux部署的Docker
linux·vscode·docker
名誉寒冰4 分钟前
GDB 调试与 Core Dump(段错误)排查指南(Linux/C/C++)
linux·c语言·c++
fufu03118 分钟前
Linux环境下的C语言编程(四十六)
linux·运维·服务器
巴拉巴拉~~28 分钟前
KMP 算法通用进度条组件:KmpProgressWidget 多维度 + 匹配进度联动 + 平滑动画
java·服务器·前端
REDcker39 分钟前
TCP/IP 协议栈详解:协议栈是什么意思?为什么叫“协议栈”?
网络·网络协议·tcp/ip
qq_418247881 小时前
Linux上部署conda环境
linux·运维·神经网络·机器学习·conda
凯子坚持 c1 小时前
Docker网络架构深度解析:从原理到实战
网络·docker·架构
cdprinter1 小时前
信刻光盘数据自动回读系统,多重保障数据安全及调阅便捷性!
网络·安全·自动化
行走的领路人2 小时前
同步服务器时间
运维·服务器
wdfk_prog2 小时前
[Linux]学习笔记系列 -- [fs]dcache
linux·数据库·笔记·学习·ubuntu