1、ArrayList和linkedList的区别
它们都是继承自 Collection。
ArrayList 是基于数组的,在使用查询的时候效率比较高,但删除效率却非常低,因为它需要重新排数组中的所有数据。
LinkList底层是一个双链表,在添加和删除元素时更好的性能,但查询效率却非常低。
2、try catch finally,try里有return,finally还执行么?
首先,不管有没有异常,finally模块肯定会执行的,哪怕 try 里有 return,也是一样。
还有就是,finally中最好不要包含return,否则程序会提前退出,返回值不是try或catch中保存的返回值。
3、能简单的介绍下多路复用 IO 模型吗
多路复用 IO 模型其实就是NIO,在这个模型中,它会有一个线程,不断的去轮询socket的状态,如果socket发生真正的读写事件时,才会真正的调用实际上的读写操作。
它的优势就在于,在该模型下,只需要一个线程,就可以管理多个socket的状态。系统不需要再额外建立,或者去管理多个线程,极度节省了系统线程资源。
成于轮询,败于轮询,它是对到达的事件,进行逐一响应,所以一旦如果事件响应体较大,就会导致后续的事件迟迟得不到响应,会影响功能上的进度。