JavaBIO:传统的阻塞模式
同步且阻塞(传统阻塞性),服务器实现模式为一个连接一个服务器,即客户端有连接请求时服务器就需要启动一个线程进行处理,
如果这个连接不做任何事情会造成不必要的线程开销
下图为BIO简单执行流程
传统的阻塞式
BIO的缺点是客户端一直在连接服务器,服务器会为每一个客户端开辟一个线程对客户端处理,但有时客户端不是一直对服务器进行IO操作的,所以这样会导致服务器阻塞,进而对服务器产生很多不必要的线程开销,资源浪费
JavaNIO:同步非阻塞
同步非阻塞,服务器实现模式为一个线程处理多个请求(连接),即客户端发送的连接请求都会注册到多路复用器上(Selector),
多路复用轮询到连接有I/O请求就进行处理
下图为NIO简单执行流程