什么是Python中的Io多路复用

 时间:2024-10-13 16:00:22

1、IO multiplexing(IO多路复用)IO多路复用,有些地方称之为event driven IO(事件驱动IO)。它的好处在于单个进程可以处理多个网络IO请求。select/epoll这两个是函数,它会不断轮询所有的socket,直到某个socket就绪有数据可达,就会通知用户进程,当用户进程调用了select函数,select是一个阻塞方法,会把进程阻塞住,同时会监听所有select负责的socket,当任何一个socket中的数据准备好了,select就会返回。这个时候用户进程再调用readRecv操作,将数据从内核拷贝到用户进程。

什么是Python中的Io多路复用

2、select虽然是阻塞的,但是它的优势在于它可以用一个进程处理多个连接,这个利用非阻塞的轮询方式是无法实现的,当连接数增多时优势就明显,而对于单个连接则跟同步IO区别不大甚至性能还要更低。s髫潋啜缅elect,poll,epoll都是IO多路复用的机制,IO多路复用就是通过机制用一个进程监视多个描述符,一旦某个描述符就绪(可读或者可写或者异常),能够通知进程进行响应的操作。但是select,poll,epoll本质上是同步IO,因为他们都需要在读写事件就绪后自己负责读写,这个过程是阻塞的。相关推荐:《Python视频教程》下面用Python的socket编程模拟IO多路复用(IO多路复用+回调+事件循环)

什么是Python中的Io多路复用

3、过程:发送一个socket请求设置为非阻塞,在select函数中注册事件,sel酆璁冻嘌f.con.fileno表示当酡箔挝棍前连接在进程中的描述符,EVENT_WRITE表示socket准备是否就绪,self.connected为回调函数,准备完成后就调用。selector.unregister(key.fd)取消注册,发送HTTP请求,再调用selector.register(self.con.fileno(), EVENT_READ, self.read)注册,若当前请求内容可读,则调用read回调函数读取出响应内容。注明:在windows下会调用select函数,而在linux/unix下则会调用epoll函数。完整代码如下:

什么是Python中的Io多路复用
  • 山胡椒辣椒油
  • 手肘肤色暗沉怎么办?
  • 联想g480怎么装xp系统
  • 绝地求生刺激战场如何获得M416武器皮肤
  • 如何进行网络测速
  • 热门搜索
    五一手抄报 祭英烈手抄报 数学手抄报内容 手抄报 春天的手抄报 建党节手抄报 我读书我快乐手抄报 植树节手抄报图片 手抄报版面设计图大全 爱眼护眼手抄报内容