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

相关推荐
AI周红伟44 分钟前
周红伟:运营商一季度净利集体下滑 Token运营提速
大数据·网络·人工智能
呱呱巨基1 小时前
Linux 基础IO
linux·c++·笔记·学习
marsh02061 小时前
43 openclaw熔断与降级:保障系统在异常情况下的可用性
java·运维·网络·ai·编程·技术
汽车仪器仪表相关领域2 小时前
Kvaser Memorator Professional 5xHS CB:五通道CAN FD裸板记录仪,赋能多总线系统集成测试的旗舰级核心装备
大数据·网络·人工智能·单元测试·汽车·集成测试
初学者,亦行者3 小时前
计算机网络必考:一文吃透 TCP/IP 体系结构(附高清思维导图)
网络·tcp/ip
萑澈3 小时前
智能增强与范式演进:OpenClaw 与 Hermes Agent 自我学习机制深度研究报告
学习
段一凡-华北理工大学3 小时前
【高炉炼铁领域炉温监测、预警、调控智能体设计与应用】~系列文章10:实时预警机制:跑在问题前面!
网络·人工智能·python·知识图谱·高炉炼铁·工业智能体
WJ.Polar3 小时前
Scapy基本应用
linux·运维·网络·python
@insist1234 小时前
信息安全工程师-入侵检测核心技术、APT 应对与工程实践
网络·安全·软考·信息安全工程师·软件水平考试
xuhaoyu_cpp_java4 小时前
Spring学习(一)
java·经验分享·笔记·学习·spring