Water2Wine

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

前导知识:同步与异步、阻塞与非阻塞

1. 同步与异步

同步与异步关注的时消息通信机制
同步,就是在发出一个调用时,在没有得到结果之前,该调用就不返回。但是一旦调用返回,就得到返回值了。
而异步则是相反,调用在发出之后,这个调用就直接返回了,所以没有返回结果。换句话说,当一个异步过程调用发出后,调用者不会立刻得到结果。而是在调用发出后,被调用者通过状态、通知来通知调用者,或通过回调函数处理这个调用。

2. 阻塞与非阻塞

阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态。
阻塞调用是指调用结果返回之前,当前线程会被挂起。调用线程只有在得到结果之后才会返回。
非阻塞调用指在不能立刻得到结果之前,该调用不会阻塞当前线程。

可以拿水壶的例子来说明同步异步与阻塞非阻塞。

  1. 老张把水壶放到火上,立等水开。(同步阻塞)
  2. 老张把水壶放到火上,去客厅看电视,时不时去厨房看看水开没有。(同步非阻塞)老张还是觉得自己有点傻,于是变高端了,买了把会响笛的那种水壶。水开之后,能大声发出嘀~~~~的噪音。
  3. 老张把响水壶放到火上,立等水开。(异步阻塞)老张觉得这样傻等意义不大
  4. 老张把响水壶放到火上,去客厅看电视,水壶响之前不再去看它了,响了再去拿壶。(异步非阻塞)

IO模块类型

  • BIO:同步阻塞

  • NIO:同步非阻塞

  • AIO:异步非阻塞

IO类型

  • InputStream、OutputStream 基于字节操作的 IO

  • Writer、Reader 基于字符操作的 IO

  • File 基于磁盘操作的 IO

  • Socket 基于网络操作的 IO

posted on 2020-03-15 13:52  Water2Wine  阅读(269)  评论(0编辑  收藏  举报