嵌入式学习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

相关推荐
superior tigre1 小时前
C++学习:六个月从基础到就业——模板编程:模板特化
开发语言·c++·学习
·醉挽清风·1 小时前
学习笔记—双指针算法—移动零
c++·笔记·学习·算法
艾醒(AiXing-w)1 小时前
探索大语言模型(LLM):自监督学习——从数据内在规律中解锁AI的“自学”密码
人工智能·学习·语言模型
山猪打不过家猪2 小时前
(六)RestAPI 毛子(外部导入打卡/游标分页/Refit/Http resilience/批量提交/Quartz后台任务/Hateoas Driven)
网络·缓存
weixin138233951792 小时前
EN18031测试,EN18031认证,EN18031报告解读
网络
JhonKI2 小时前
【Linux网络】构建与优化HTTP请求处理 - HttpRequest从理解到实现
linux·网络·http
GOATLong3 小时前
网络基础概念
linux·运维·服务器·网络·arm开发·c++
搏博3 小时前
机器学习之三:归纳学习
人工智能·深度学习·学习·机器学习
技术liul3 小时前
如何在iStoreOS DHCP中排除特定IP地址
网络·windows·tcp/ip
AgilityBaby3 小时前
unity Animation学习,精准控制模型动画播放
学习·3d·unity·游戏引擎