zoukankan      html  css  js  c++  java
  • java IO 模型--快速分清 同步|阻塞

    IO 介绍

    IO 模型

    IO请求 分为两个阶段:等待资源 和 使用资源;
    IO请求:一般需要请求特殊资源(如 磁盘、RAM 或文件),当资源被上一个使用者使用没有释放的时候, IO请求会被阻塞,直到资源可用。

    等待资源 阶段有两种策略:

    • 阻塞:当IO请求资源没有准备好的时候,请求阻塞,直到得到资源的响应(有资源 或者 超时异常);
    • 非阻塞:资源不可用时,IO请求直接返回,返回数据不可用标志。

    使用资源 阶段,IO 分为 同步IO 和 异步IO

    • 同步IO:应用阻塞在发送数据和接受数据阶段,直到数据发送或接收完毕 或 失败返回;
    • 异步IO:应用发送或接受数据后,即返回,数据写入OS 缓存,由OS 完成数据的发送或接受,完成后,发送成功后失败标志给应用。

    Unix IO 模型

    • 阻塞IO:等待资源阻塞,使用资源同步;
    • 非阻塞IO:等待资源轮询,使用资源同步;
    • IO 复用:支持多路复用,等待阻塞在复用选择器上,使用资源同步的方式;
    • 信号驱动 :等待资源通知,使用资源同步;
    • 异步IO :等待 和 使用 采用通知的方式。

    各种IO特点:

    • 阻塞IO:使用简单,但是每个socket请求会新建一个线程处理,这些线程大多数是没有运算的,造成线程的膨胀;Java BIO 使用这种方式。
    • 非阻塞IO:采用轮询的方式,因此不会造成线程的膨胀。java NIO 采用这种方式,大大减少了线程数,可以使用一个线程完成对所有socket 的监听。
      另外,NIO 底层采用多路复用IO的方式(select阻塞,支持多路复用),但是java 的实现接口,采用了轮询的方式,貌似一种非阻塞的形态。
    • 同步IO:IO 操作结束之后才返回,效率低些,但是编程方式简单。java BIONIO 都是采用这种方式。
    • 异步IO:由于异步IO 只是写入了缓存,由缓存到磁盘成功与否未可知,因此异步IO 相当于把IO操作分成了两部分:发起请求,获取返回结果。因此对应用来说增加了编程复杂性。
      但是异步IO的性能是非常好的,而异步的思想贯穿了IT系统的方方面面。

    一些概念:
    1、 IOPS:每秒处理的IO 数量。
    2、多路复用技术:
    信号通路的带宽大于单一信号的数据量大小,为了有效利用带宽,希望信号通路可以一次性传递多个信号数据,这就是多路复用技术。
    nio中就是,一个线程可以监听多个通信信道(不同的socket),所以是多个通信信道复用一个监听|轮询线程,即多路复用
    分类:频分多路复用 和 时分多路复用

    IO 组合方式:
    IO 组合方式

  • 相关阅读:
    6、深入理解计算机系统笔记:存储器层次结构,存储技术(1)
    流程图【占无内容】
    程序的三种基本控制架构【只有提纲】
    Console算法[for]穷举法:百钱买百鸡
    Logic算法(狼羊白菜)
    Console算法continue与break的区别?
    Console算法[for]简单画图
    Console算法[for]输出等腰三角形
    Console算法[for]国王与老人的六十四格
    Console算法[for]素数
  • 原文地址:https://www.cnblogs.com/paxing/p/10664920.html
Copyright © 2011-2022 走看看