阅读jdk1.8源码小收获
2017-11-20 23:18
309 查看
分享一个阅读源码中收获的小的优化方案。
在创建一个Boolean时,Boolean b = true;不是一个好的方案,在源码中有一个更好的 建议,可以节省时间和空间
Boolean bool = Boolean.valueOf(true);
这个是jdk源码推荐的方法
源码和注释如下:
阅读了Integer的源码 valueOf也是取的缓存中的值。
注意:Integer a = 3;这种情况默认走 valueOf() !!! Boolean b = true;也是默认走valueOf()方法!!
在创建一个Boolean时,Boolean b = true;不是一个好的方案,在源码中有一个更好的 建议,可以节省时间和空间
Boolean bool = Boolean.valueOf(true);
这个是jdk源码推荐的方法
源码和注释如下:
/** * Returns a {@code Boolean} instance representing the specified * {@code boolean} value. If the specified {@code boolean} value * is {@code true}, this method returns {@code Boolean.TRUE}; * if it is {@code false}, this method returns {@code Boolean.FALSE}. * If a new {@code Boolean} instance is not required, this method * should generally be used in preference to the constructor * {@link #Boolean(boolean)}, as this method is likely to yield * significantly better space and time performance. * * @param b a boolean value. * @return a {@code Boolean} instance representing {@code b}. * @since 1.4 */ public static Boolean valueOf(boolean b) { return (b ? TRUE : FALSE); }
阅读了Integer的源码 valueOf也是取的缓存中的值。
/** * Returns an {@code Integer} instance representing the specified * {@code int} value. If a new {@code Integer} instance is not * required, this method should generally be used in preference to * the constructor {@link #Integer(int)}, as this method is likely * to yield significantly better space and time performance by * caching frequently requested values. * * This method will always cache values in the range -128 to 127, * inclusive, and may cache other values outside of this range. * * @param i an {@code int} value. * @return an {@code Integer} instance representing {@code i}. * @since 1.5 */ public static Integer valueOf(int i) { if (i >= IntegerCache.low && i <= IntegerCache.high) return IntegerCache.cache[i + (-IntegerCache.low)]; return new Integer(i); }
注意:Integer a = 3;这种情况默认走 valueOf() !!! Boolean b = true;也是默认走valueOf()方法!!
Integer c2 = new Integer(1); 官方不推荐这种建对象的方法喔
相关文章推荐
- 【JDK1.8】JDK1.8集合源码阅读——TreeMap(一)
- Java Jdk1.8 HashMap源码阅读笔记一
- JDK1.8源码阅读系列之二:LinkedList
- jdk1.8 J.U.C并发源码阅读------CountDownLatch源码解析
- jdk1.8 J.U.C并发源码阅读------CyclicBarrier源码解析
- [Jdk1.8源码阅读]ArrayList
- JDK1.8源码阅读之——String,StringBuffer, StringBuilder
- jdk1.8 J.U.C并发源码阅读------ReentrantReadWriteLock源码解析
- jdk 1.8 hashmap resize 源码阅读
- Java Jdk1.8 HashMap源码阅读笔记二
- JDK 1.8 HashMap 源码阅读一
- JDK 1.8 HashMap 源码阅读二
- 【JDK1.8】JDK1.8集合源码阅读——TreeMap(二)
- 【JDK1.8】JDK1.8集合源码阅读——IdentityHashMap
- 【JDK1.8】JDK1.8集合源码阅读——Set汇总
- 【JDK1.8】JDK1.8集合源码阅读——LinkedList
- JDK1.8源码阅读之——VECTOR,ARRAYLIST, LINKEDLIST
- JDK 1.8 ArrayBlockingQueue 源码阅读(一)插入
- JDK 1.8 ArrayBlockingQueue 源码阅读(二)获取
- Java Jdk1.8 HashMap源码阅读