嵌入式学习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相同                                                 无法工作在边沿触发(高速模式)

水平触发:产生事件通知,没处理完成,下次继续通知此事件,阻塞在这里,直到处理完成此事件(低速)。

边沿触发:产生事件的时刻通知,只通知一次,下次通知其它事件,不阻塞。

poll:内部链表结构,所以无上限。

  
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 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/739584.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

群晖NAS使用Docker安装WPS Office并结合内网穿透实现公网远程办公

文章目录 推荐1. 拉取WPS Office镜像2. 运行WPS Office镜像容器3. 本地访问WPS Office4. 群晖安装Cpolar5. 配置WPS Office远程地址6. 远程访问WPS Office小结 7. 固定公网地址 推荐 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默&#xff…

社交创新的先锋:探秘Facebook背后的故事与智慧

起源与初创阶段 Facebook的故事始于2004年,由马克扎克伯格(Mark Zuckerberg)、埃迪华索伦(Eduardo Saverin)、安德鲁麦克卡拉姆(Andrew McCollum)、克里斯休斯(Chris Hughes&#x…

如何保证消息的顺序性

先看看顺序会错乱的场景:RabbitMQ:一个 queue,多个 consumer,这不明显乱了: 解决方案:

Qt/QML编程之路:openglwidget和倒车影像的切换(43)

关于如何实现一个基于OpenGL的3d 图形,这个有很多专门的介绍,我在开发中遇到了这么一个问题: 如何实现一个倒车影像的video显示与一个3D物体显示的切换,因为开窗在同样的一个位置,如果车子倒车启动,则需要将原本显示3D的地方切换为视频图像的显示。 class testOpenGl : …

【办公类-22-13】周计划系列(5-5)“周计划-05 上传周计划png“ (2024年调整版本)

作品展示——将docx 转PDF转png,保留第一张图片 背景需求: 把周计划内容初步替换后,获得了19周的周计划教案的docx 需要把周计划第一页的反思内容删除,,然后把第一页横版截图上传班级主页。 需求:周计划do…

云桥通SDWAN企业组网的15大应用场景

云桥通SD-WAN企业组网技术在企业网络中有多样化的应用场景,在技术不断迭代升级中,已经越来越匹配现在的互联网环境,其中在这15中常见的应用场景中,使用云桥通SDWAN企业组网可以很好的帮到企业: 分支机构连接优化&#…

C#判断素数的方法:试除法 vs 优化的试除法 vs 米勒-拉宾素数检测算法

目录 1.素数也就质数 2. 试除法 3.优化的试除法_1 4.优化的试除法_2 5.优化的试除法_3 6.米勒-拉宾素数检测算法 1.素数也叫质数 一个质数是一个大于1的自然数,只有两个正因数:1和它自身。这意味着如果一个数只有两个正因数,那么它就是…

#QT(QSpinBox,QDoubleSpinBox)

1.IDE:QTCreator 2.实验:实现一个计价工具,进制转换工具。 教程来自:阿西拜编程 QT C 5.9 3.记录 设置进制的第二种方法 ui->hex_tx->setDisplayIntegerBase(16); //设置显示进制为16进制 4.代码 widget.cpp #include "wi…

做一下笔记 CXDB5CCAM-MK 与 CXDBCCAM-ML 的区别

1. CXDB5CCAM-MK 的简介 2. CXDBCCAM-ML 的简介 3. 这个两个器件的区别 最基本可见的区别是 : 传输速度的不同。 4. 资料在资源里面

智能计算的基本原理——智能计算原理与实践【文末送书-36】

文章目录 智能计算的基本原理基本原理技术智能计算在实践中的应用 智能计算:原理与实践【文末送书-36】 随着科技的不断发展,智能计算成为引领时代的前沿技术之一。从传统的计算机模型到如今的人工智能系统,智能计算不仅深刻地改变着我们的生…

Python学习:首选开发环境VScode

Visual Studio Code 打开官网 https://code.visualstudio.com/,下载软件包,一步步安装即可。 我认为Visual Studio Code最好的Web前端开发工具。 Visual Studio Code是什么 Visual Studio Code (简称 VS Code) 是一款由 Microsoft 开发的轻量级、免费和…

深入探究:AVL树的平衡之道

文章目录 一、AVL树的原理AVL树的定义和特性平衡因子的概念 二、AVL树的自平衡策略a. 单旋(single rotation)1. 左单旋(Left Rotation):2. 右单旋(Right Rotation): b. 双旋&#xf…

低功耗DC-DC电压调整器IU5528D

IU5528D是一款超微小型,超低功耗,高效率,升降压一体DC-DC调整器。适用于双节,三节干电池或者单节锂电池的应用场景。可以有效的延长电池的使用时间。IU5528D由电流模PWM控制环路,误差放大器,比较器和功率开关等模块组成。该芯片可在较宽负载范围内高效稳…

自学软件测试真的能找到工作吗?“我“的测试之路...

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 自学软件测试当然…

【C++】C++学习前言

C前言与发展 一.什么是C二.C的发展史三.C的重要性 一.什么是C C语言是结构化和模块化的语言,适合处理较小规模的程序。对于复杂的问题,规模较大的程序,需要高度的抽象和建模时,C语言则不合适。为了解决软件危机, 20世纪…

猫生骨肉冻干价格合理区间是多少?真正性价比高的生骨肉冻干推荐

随着养猫知识的普及,生骨肉冻干喂养受到越来越多铲屎官的欢迎。然而,价格因素仍是部分铲屎官的阻碍。实际上,像我这样的资深铲屎官,早已认识到生骨肉冻干的价值。虽然生骨肉冻干的价格相对于烘焙粮和膨化粮要高一些,但…

前端之用HTML做一个汇款单

例子 代码 里面注释是我我对运用到的知识的理解 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>工商银行电子汇款单</title> </head> <body><h3>工商银行电子汇款单</…

面试题02.07.链表相交

方法一&#xff1a;暴力 public ListNode getIntersectionNode(ListNode headA, ListNode headB) {//先获得链表长度ListNode l1 headA;ListNode l2 headB;int m 0, n 0;while(l1 ! null){m;l1 l1.next;}while(l2 ! null){n;l2 l2.next;}ListNode l3 headA;for(int i …

什么是Redis的数据分片?

Redis的数据分片(sharding)是一种将一个Redis数据集分割成多个部分&#xff0c;分别存诸在不同的Redis节点上的技术。它可以用于将一个单独的Redis数据库扩展到多个物理机器上&#xff0c;从而提高Redis集群的性能和可扩展性 Redis数据分片的实现方式通常是将数据按照某种规则(…

独家直播!手机无人APP,让你跟上最新潮流

手机无人APP&#xff0c;是一款极具创新力和前瞻性的应用&#xff0c;旨在让用户随时随地跟上最新潮流。通过独家直播功能&#xff0c;用户可以第一时间了解世界各地的潮流资讯&#xff0c;与时俱进&#xff0c;展现出自己的个性和风采。 无人APP的直播功能实现了信息的即时传…