嵌入式学习37-TCP并发模型

TCP并发模型:

1.TCP多线程模型:

缺点:

1.创建线程 会带来 资源开销 2.能够实现的 并发量 比较有限

2.IO模型:

1.阻塞IO :

没有数据 到来时,可以让任务挂起 节省 CPU资源开销 ,提高 系统效率

2.非阻塞IO :

程序 接收到数据时一直执行 效率很低

3.异步IO

只能绑定一个 文件描述符用来 读取数据

4.多路复用IO

select

1.select监听的集合 中的文件描述符有 上限限制

2.select有 内核层用户层 数据空间 拷贝 的过程,占用系统资源开销

3.select必须 轮询检测 产生 事件 的文件描述符

4.select 只能工作水平触发 模式(低速模式 ) 无法工作边沿触发 模式(高速模式)

poll (监听的集合 中的文件描述符有 **没有上限限制)**

1.poll有 内核层用户层 数据空间 拷贝 的过程,占用系统资源开销

2.poll必须 轮询检测 产生 事件 的文件描述符

3.poll 只能工作在水平触发模式(低速模式) 与select相同 无法工作在边沿触发(高速模式)

3.函数接口:

1.select

int select(int nfds, fd_set *readfds, fd_set *writefds,

fd_set *exceptfds, struct timeval *timeout);

功能:

select 监听 文件描述符集合 中 是否 有文件描述编程 ready状态

select 监听 文件描述符集合 中**,若有状态 , 将没有ready状态的T除 若无状态,将阻塞继续等待** 参数:

nfds : 最大文件描述符的值 +1

readfds : 读 文件描述符集合

writefds : 写 文件描述符集合

exceptfds : 其余 文件描述符集合

timeout : 等待的时长

NULL 一直等待(超时处理

返回值:

成功 返回 文件描述符集合中 的 文件描述符个数

失败 返回 -1

**void FD_**CLR(int fd, fd_set *set);

功能:

将文件描述符 fd 从集合中清除

int FD_ISSET (int fd, fd_set *set);

功能:

判断 文件描述符 fd 是否仍在集合中

**void FD_**SET (int fd, fd_set *set);

功能:

将文件描述符 fd 加入到 集合中

**void FD_**ZERO (fd_set *set);

功能:

将文件描述符集合 清0

2.poll

int poll(struct pollfd *fds, nfds_t nfds, int timeout);

功能:

监听 文件描述符集合 是否事件 发生

参数:

fds : 监听 文件描述符集合 数组空间首地址

nfds : 监听 文件描述符集合 元素个数

timeout : 等待的时间**(非0)** (-1 一直等待

返回值:

成功 返回 产生事件的文件描述符 个数

失败 返回 -1

struct pollfd {

int fd; /* file descriptor */

short events; /* requested events */

short revents; /* returned events */

};

fd : 监听的文件描述符

events : 要监听的 事件 POLLIN: 是否 可读 POLLOUT: 是否 可写

revents : 实际 产生的 事件

3.epoll

int epoll_create(int size);

功能:

创建 一张 内核事件表

参数:

size: 事件的 个数

返回值:

成功返回文件描述符

失败返回-1

epoll_ctl

int epoll_ctl(int epfd, int op, int fd, struct epoll_event *event);

功能:

维护 epoll时间表

参数:

epfd : 事件表 的文件描述符

op :

EPOLL_CTL_ADD 添加事件

EPOLL_CTL_MOD 修改事件

EPOLL_CTL_DEL 删除事件

fd :

操作 的文件描述符

event :

事件 对应的事件

typedef union epoll_data {

void *ptr;

int fd;

uint32_t u32;

uint64_t u64;

} epoll_data_t;

struct epoll_event {

uint32_t events; /* Epoll events */

epoll_data_t data; /* User data variable */

};

返回值:

成功返回0

失败返回-1

epoll_wait

int epoll_wait(int epfd, struct epoll_event *events,

int maxevents, int timeout);

功能:

监听 事件表中事件

参数:

epfd : 文件描述符

events : 存放 实际产生事件 的数组空间 首地址

maxevents : 最多 存放事件 的个数

timeout : 设定 监听的时间(超过 该时间 则不再监听

-1 一直监听直到有事件发生

返回值:

成功返回产生事件的文件描述符个数

失败返回-1

如果时间达到 仍没有事件发生 返回0

相关推荐
MrSYJ3 天前
TCP协议理解
后端·tcp/ip
通信小呆呆14 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
H__Rick14 天前
自动对焦学习-3
人工智能·学习·计算机视觉
Daisy Lee14 天前
量化学习-第1章-什么是量化金融
学习·金融·datawhale
Alsn8614 天前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker
YM52e14 天前
买菜计算器小应用 - HarmonyOS ArkUI 开发实战-PC版本
学习·华为·harmonyos·鸿蒙·鸿蒙系统
网络研究院14 天前
2026年网络安全
网络·安全·法律·法规·趋势·发展
酣大智14 天前
ARP代理--工作原理
运维·网络·arp·arp代理
treesforest14 天前
AI安全系统如何识别异常访问?IP风险识别正在成为关键能力
网络·人工智能·tcp/ip·安全·web安全
小雨下雨的雨14 天前
HarmonyOS ArkUI训练营入门-组件掌握系列-Animation 动画效果实现-PC版本
学习·华为·harmonyos·鸿蒙