BIO
基于流模型实现的,交互的方式是同步、阻塞方式,在处理IO的输入或输出,线程会一直阻塞在那里,它们之间的调用时可靠的线性顺序。优点就是代码比较简单、直观;缺点就是IO的效率和扩展性很低,容易成为应用性能瓶颈。
NIO
是Java1.4引入的java.nio 包,提供了Channel、Selector、Buffer 等新的抽象,可以构建多路复用的、同步非阻塞IO程序,同时提供了更接近 *** 作系统底层高性能的数据 *** 作方式,一个线程可以做N件事情
AIO
是 Java 1.7 之后引入的包,是NIO的升级版本,提供了异步非堵塞的 IO *** 作方式,称呼为AIO(AsynchronousIO),异步IO是基于事件和回调机制实现的,也就是应用 *** 作之后会直接返回,不会堵塞在那里,当后台处理完成, *** 作系统会通知相应的线程进行后续的 *** 作
应用场景:校园内的打饭
BIO:排队打饭,每个学生排队打饭,当学生选好饭菜,并且阿姨打好饭菜才能轮到下位同学
NIO:同样是打饭,所有同学将点的饭菜提前安排一位同学拿着点单情况在食堂等着,观察每一个同学的点单的状态,通知对应的同学
AIO:学生提前将点单然后阿姨给同学发放示警器,饭菜好了阿姨触发示警器自动通知对应的学生
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)