程序员技术干货

高并发技术之深入浅出Java NIO原理(一)

2017-07-05  本文已影响278人  阿拉斯加不撕家

本文旨在用最通俗的思路去传递设计者最牛X的思想,如若觉得文中的比喻有不恰当之处,欢迎指正并与我交流,我们一起学习、相互鼓励、共同进步!

最近因公司需要开发即时通讯系统,所以花了大量时间去研究学习NIO、AIO以及Netty框架,在这个学习的过程中,受益匪浅,尤其是Netty的设计思想,真是让我欲罢不能,脑洞大开。好了,废话不多说,开始我们今天的正题。

在学习NIO之前,务必理解、掌握以下两组核心概念:

1、同步、异步

2、阻塞、非阻塞

在学习以上两组概念之前,我们先看看什么是参照物:

       在研究机械运动时,人们事先选定的、假设不动的,作为基准的物体叫做参照物。(一般不以研究对象为参照物)通常情况下,多以地面为参照物。参照物可以任意选定。选择不同的参照物来描述同一个物体的运动状态,可能得出不同结论,所以运动和静止都是相对的。在研究地面上物体的机械运动时,通常以与地面保持相对静止的物体作为参照物。

没错,聪明的你也许已经猜到了,这两组概念就是基于参照物的选取来理解的。

同步、异步:

参照物:时间

描述:在同一时间点或者同一时间段内,能不能同时完成多个任务,同时做多件事

好了,为了更深刻的理解同步、异步的概念,下面我们再来看一个简单的事件描述例子:

事件:银行办理存款业务

流程:取号机取号--->等待叫号

状态一:此刻我是不能离开银行的,因为银行业务是过号不等,而此刻公司老板打电话来交代了一件重要的事必须要处理,但是我又不能离开银行

状态二:经过反复思想斗争,一个电话把老婆叫过来,到银行排队,然后我就去给老板办事去了。老婆业务办好以后,再电话通知我

阻塞、非阻塞:

参照物:数据准备状态

描述:数据在当前状态是否已准备好

同样,为了更加深刻的理解阻塞、非阻塞的概念,我们再看一个事件描述例子:

事件:银行办理存款业务

流程:取号机取号--->等待叫号

状态一:在银行休息区,为了打发等待叫号的时间,我拿出手机开始玩王者荣耀,而此刻,漂亮的大堂经理给我送来了一杯茶,一边喝着美女送来的茶,一边玩着王者荣耀。不一会儿,就叫到我的号了,大堂经理领着我就去了柜台后面(表示数据已准备好)。

状态二:我在等待叫号的时候,什么都不想做,看着柜台前排着长长的队伍,队伍的最后正好是个美女,我就屁颠屁颠的去站在了美女的身后跟着排队了(哎,美女也不说话,排队的队伍还这么长)

哈哈,在看了以上例子之后,此时的你可能已经隐隐约约开始理解了这两组概念的含义,但是可能又有一点点蒙圈。那好,现在我们再来看这两组概念的通俗解释:

同步:在同一个时间点或者同一个时间段内,只能做一件事情

异步:在同一个时间点或者同一个时间段内,可以完成多件事情

阻塞:数据没有准备好,那么程序就处于一个阻塞状态,不会继续往下执行

非阻塞:不管数据有没有准备好,程序都依旧往下执行

怎么样,看完这么一组通俗的解释再回过头去结合上面的事件例子,是不是已经完全掌握并理解了什么是同步、异步以及阻塞、非阻塞?简直不要太so easy!!!

趁热打铁,现在我们再来看传统BIO和NIO的区别:

Java NIO与传统IO的区别

相信聪明的你学习到这里,已经对Java NIO的基本概念有了一个基本的理解及掌握,有了这些基础做铺垫,下节我们将一起“深入”到NIO的核心区域学习NIO,一层一层的剥开NIO的衣裳,让她在你面前一览无余!

欢迎在留言区说出你的想法,我们一起思想碰撞,一起进步!






上一篇下一篇

猜你喜欢

热点阅读