zoukankan      html  css  js  c++  java
  • I/O与NIO(异步I/O)

    1、原来的I/O库与NIO最重要的区别是数据打包和传输方式的不同,原来的I/O以流的方式处理数据,而NIO以块的方式处理数据

    面向流的I/O系统一次一个字节地处理数据。一个输入流产生一个字节的数据,一个输出流消费一个字节的数据;

    使用块IO的处理方式,每一个操作都在一步中产生或者消费一个数据块

    2、异步IO是一种“没有阻塞地读写数据”的方法。通常,在代码进行read()调用时,代码会阻塞直至有可供读取的数据。同样,write()调用将会阻塞直至数据能够写入。但异步I/O调用不会阻塞,相反,您可以注册对特定I/O事件的兴趣:如可读的数据到达、新的套接字连接等等,而在发生这样的事件时,系统将会告诉您。

    异步I/O的一个优势在于,它允许您同时根据大量的输入和输出执行I/O,同步程序常常求助于轮询,或者创建许许多多的线程以处理大量的连接。使用异步I/O,您可以监听任何数量的通道上的事件,不用轮询,也不用额外的线程

  • 相关阅读:
    014_Python3 循环语句
    013_Python3 条件控制
    012_Python3 斐波纳契数列 + end 关键字
    011_Python3 集合
    010_Python3 字典
    009_Python3 元组
    008_Python3 列表
    006_Python3 数字(Number)
    005_Python3 运算符
    bzoj3160
  • 原文地址:https://www.cnblogs.com/wangle1001986/p/3579289.html
Copyright © 2011-2022 走看看