zoukankan      html  css  js  c++  java
  • 同步异步,阻塞非阻塞的相关说明

    关于阻塞与非阻塞 同步与异步的区别:一般来说IO分为两个阶段,

    第一阶段是等待数据阶段,

    第二阶段是内核空间的数据拷贝到用户空间,假设一个线程(或是进程)P准备执行一个IO操作的话它会经历以下过程:

    第一阶段:

    P发出一个IO请求,这时候会有两种情况: 1:立刻返回: 非阻塞 2:一直等待,P调用sleep/wait休眠或是挂起,让出CPU给别的线程/进程 阻塞

    第二阶段:

    这时内核的数据终于准备好了, 那么现在用户进程想要读取内核空间的数据有两种方式: 1: P自己把数据从内核空间拷贝到用户空间 同步

    2:P创建一个线程做数据copy的工作 异步 现在应该明白了吧。阻塞/非阻塞是针对IO的第一阶段的描述。异步/同步是针对IO的第二阶段的描述也就是IO的主体。

    这里主要比较难理解的就是同步/异步。首先P在发起IO的请求的时候如果P本身还要负责IO请求后的数据copy(内核空间到用户空间)工作。那么我们就可以说是同步的。

    如果P在发起IO操作后数据copy的工作由内核线程/进程或是P自己再创建一个线程/进程去完成,那么我们就可以称之为异步

  • 相关阅读:
    Codeforces Round #363 (Div. 2)
    Codeforces Round #312 (Div. 2)
    Codeforces Round #354 (Div. 2)
    Codeforces Round #353 (Div. 2) A
    Codeforces Round #347 (Div. 2) B
    Codeforces Round #326 (Div. 2)
    Spring中数据库技术--获得DataSource
    查询练习
    查询语句
    Oracle数据库的使用
  • 原文地址:https://www.cnblogs.com/anqli-java/p/9929503.html
Copyright © 2011-2022 走看看