什么是同步?异步?

同步:针对应用程序和内核的交互而言,同步指的是用户进程触发IO操作并等待或者轮询的去查看IO操作是否就绪

可以看成单线程
是安全的,但是因为有同步的机制在,所以性能相对较差

异步:异步是指用户进程触发IO操作以后便开始做自己的事情,而当IO操作已经完成的时候会得到IO完成的通知

  • 可以看成多线程
  • 异步不安全的,容易导致死锁(比如两个线程都持有对方的锁,互不释放,存在死锁),这样一个线程死掉可能会导致整个进程崩溃,但是因为没有同步机制存在,多线程异步执行,性能有所提升
  • 异步编程是我们程序并发运行的一种手段
  • 并发指多条线程去争抢一个CPU执行资源
  • 并行是指多条线程分布在不同的CPU核心上执行任务

阻塞与非阻塞

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