同步、异步、阻塞、非阻塞概念
- 阻塞、非阻塞
IO操作分两部分,发起IO请求和IO数据读写,阻塞、非阻塞主要是针对线程发起IO请求后,是否立即返回 - 同步、异步
针对IO数据读写定义的,读写数据过程不阻塞线程称为异步IO
阻塞IO模型
最传统的一种IO模型,在读写数据的过程中会发生阻塞现象,
当用户线程发出IO请求之后,内核会去查看数据是否准备就绪,如果没有准备就绪就会等待数据就绪,而用户线程就会处于阻塞状态,用户线程交出CPU。
数据准备就绪后,内核会将数据拷贝到用户线程,并返回结果给用户线程,用户线程才解除block状态
比如 java.io 包 ,基于流模型实现,交互方式是同步,阻塞的方式,在读取输入流或写入输出流时候,在读,写动作完成之前,线程会一直阻塞
还有java.net下面提供的部分网络API,比如 Socket、ServerSocket、HttpURLConnection 也归类到同步阻塞 IO 类库,因为网络通信同样是 IO 行为
非阻塞IO模型
当用户线程发起一个read操作后,不需要等待,马上得到了一个结果,如果结果是error时,就表示数据还没有准备好,用户线程可以继续发送read操作,一旦内核中的数据准备好了,并且又再次收到了用户线程的请求,它马上将数据拷贝到用户线程,然后返回
在非阻塞IO模型中用户线程需要不断询问内核数据是否就绪,也就是不会交出CPU,导