面试部分难点梳理 - IO多路复用

本文详细探讨了Linux操作系统中的IO多路复用,重点关注NIO和epoll。讨论了中断的分类,系统中断时内核执行的任务,以及Socket的读写缓冲区机制。在BIO和NIO的对比中,解释了它们在写入和读取数据时的不同处理方式。此外,文章还介绍了从用户态到内核态的切换,并详细阐述了select和epoll两种多路复用机制的工作原理及epoll相对于select的优势。
摘要由CSDN通过智能技术生成

IO多路复用

  • 如果用JUC的方式来类比理解一下,BIO是相当于整个APP都加了synchronied,NIO相当于是使用自旋的方式。
    在这里插入图片描述

Linux操作系统中断

中断的分类

  • 内中断:陷入(系统调用),故障(缺页中断),终止(程序BUG)
  • 外中断: I/O中断请求(设备准备就绪),人工干预(Ctrl + C);
    在这里插入图片描述

系统中断,内核做什么事情

内核态 - 执行系统调用

Socket

Socket基础

在这里插入图片描述

在这里插入图片描述

Socket读写缓冲区机制

用户态和内核态

  • Socket在底层采用TCP/IP协议,因此在数据传输的过程中是可以保证可靠性的。
  • APP处于用户态,是无法处理TCP/IP协议的,必须要将其所需要传输的数据通过系统调用,传输到操作系统的内核空间中。
  • 当操作系统处于内核态时,可以通过底层的方法,建立Socket连接,来传输数据。

缓冲区

  • APP在用户空间中也有缓冲区,操作系统在内核空间中也有缓冲区。
  • 内核空间的缓冲区是用来接收/发送TCP/IP传输过程中的数据缓冲。
  • 用户空间的缓冲区是用来读取/写入内核缓冲区中的数据。
  • 内核缓冲区中分成了输入缓冲区,和输出缓冲区。

BIO

  • 如果一个APP写入输入缓冲区时,会对输出缓冲区加锁,同一时间仅仅能有该APP执行输入输出操作,如果输出缓冲区不足,也会加锁,
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值