简单说几个JDK1.7和JDK1.8的区别?
1.Switch支持String类型
2.Catch多个异常
catch(IOException | SQLException | Exception ex){
logger.error(ex);
throw new MyException(ex.getMessage());
}
3.泛型实例创建可以通过类型推断简化,new对象后边的泛型可以不用写,直接< >
4.HashMap性能优化:
- jdk1.8 当每个链表长度 >8 ,并且数组元素个数 ≥64时,会调整成红黑树,目的是提高效率
- jdk1.8 当链表长度 <6 时 调整成链表
- jdk1.8 以前,链表时头插入,之后为尾插入
- 原因:头插法在并发情况下会出现链表成环的问题,当然我们知道它不是线程安全的类,不会用它,并发编程时用的是Concurrent包下的ConcurrentHashMap
5.Annotation注解:支持多重注解
想了解更多请看这:Java 多重注解
6.永久代移除,把类的元数据保存在元空间(本地内存区域,也就是堆外内存)
7.实现了异步非阻塞IO(AIO)和Profactor
- IO分为BIO(同步阻塞),NIO(同步非阻塞)和AIO(异步非阻塞)
8.Lambda表达式,(例如: (x, y) -> { return x + y; } ;λ表达式有三部分组成:参数列表,箭头(->),以及一个表达式或语句块。)
9.栅栏:允许两个或多个线程在某个集合点同步,当一个线程到达集合点时,它将调用await()方法等待其它的线程。线程调用await()方法后,CyclicBarrier将阻塞这个线程并将它置入休眠状态等待其它线程的到来。等最后一个线程调用await()方法时,CyclicBarrier将唤醒所有等待的线程然后这些线程将继续执行。CyclicBarrier可以传入另一个Runnable对象作为初始化参数。当所有的线程都到达集合点后,CyclicBarrier类将Runnable对象作为线程执行。
应用场景:多个线程做任务,等到达集合点同步后交给后面的线程做汇总。