• 同步和异步、阻塞和非阻塞


    一、什么是同步和异步

    同步和异步是针对应用程序和内核的交互而言的,同步指的是用户进程或线程触发IO操作并等待或者轮询的去查看IO操作是否就绪,而异步是指用户进程出发IO操作以后便开始做自己的事情,而当IO操作已经完成的时候会得到IO完成通知。

    以银行取款为例:
    同步 : 自己亲自出马持银行卡到银行取钱(使用同步 IO 时,Java 自己处理 IO 读写);
    异步 : 委托一小弟拿银行卡到银行取钱,然后给你(使用异步 IO 时,Java 将 IO 读写委托给 OS 处理,需要将数据缓冲区地址和大小传给 OS(银行卡和密码),OS 需要支持异步 IO操作 API);

    二、什么是阻塞和非阻塞

    阻塞和非阻塞是针对于进程在访问数据的时候,根据IO操作的就绪状态来采取的不同的方式,说白了就是一种读取或者写入操作方法的实现方式,阻塞方式下读取或者写入方法将一直等待,而非阻塞方式下,读取或者写入方法会立即返回一个状态值。

    以银行取款为例:
    阻塞 : ATM 排队取款,你只能等待(使用阻塞 IO 时,Java 调用会一直阻塞到读写完成才返回);
    非阻塞 : 柜台取款,取个号,然后坐在椅子上做其它事,等号广播会通知你办理,没到号你就不能去,你可以不断问大堂经理排到了没有,大堂经理如果说还没到你就不能去(使用非阻塞 IO 时,如果不能读写 Java 调用会马上返回,当 IO 事件分发器通知可读写时再继续进行读写,不断循环直到读写完成)

  • 相关阅读:
    关于DRY原则
    类型之惑
    ThoughtWorks测试
    编程非易事
    瀑布与迭代的真实区别
    对TDD原则的理解
    自我练习
    C# CreateProcess的测试
    乱侃OOD
    复杂系统的五个属性
  • 原文地址:https://www.cnblogs.com/girl1314/p/11064561.html
Copyright © 2020-2023  润新知