JDK源碼Java.lang.Boolean的淺析
JDK源碼(jdk 1.5 b2)的研究是一個很大的范疇,那么今天先對Java.lang.Boolean開始解剖。
首先我們來看JDK源碼中Java.lang.Boolean的代碼,剔除所有的方法和靜態變量,Java.lang.Boolean的核心代碼如下:
- public final class Boolean implements java.io.Serializable,Comparable
- {
- private final boolean value;
- }
很明顯,凡是成員變量都是final類型的,一定是immutable class,這個Boolean和String一樣,一旦構造函數執行完畢,實例的狀態就不能再改變了。
JDK源碼中Java.lang.Boolean的構造函數有兩個:
- public Boolean(boolean value) {
- this.value = value;
- }
- public Boolean(String s) {
- this(toBoolean(s));
- }
都很簡單就不多說了。
另外注重到Java.lang.Boolean類實際上只有兩種不同狀態的實例:一個包裝true,一個包裝false,Java.lang.Boolean又是immutable class,所以在內存中相同狀態的Boolean實例完全可以共享,不必用new創建很多實例。因此Boolean class還提供兩個靜態變量:
- public static final Boolean TRUE = new Boolean(true);
- public static final Boolean FALSE = new Boolean(false);
這兩個變量在Class Loader裝載時就被實例化,并且申明為final,不能再指向其他實例。
提供這兩個靜態變量是為了讓開發者直接使用這兩個變量而不是每次都new一個Boolean,這樣既節省內存又避免了創建一個新實例的時間開銷。
因此,用
- Boolean b = Boolean.TRUE;
比
- Boolean b = new Boolean(true);
要好得多。
假如碰到下面的情況:
- Boolean b = new Boolean(var);
一定要根據一個boolean變量來創建Boolean實例怎么辦?
推薦你使用Boolean提供的靜態工廠方法:
- Boolean b = Boolean.valueOf(var);
這樣就可以避免創建新的實例,不信看看valueOf()靜態方法:
- public static Boolean valueOf(boolean b) {
- return (b ? TRUE : FALSE);
- }
這個靜態工廠方法返回的仍然是兩個靜態變量TRUE和FALSE之一,而不是new一個Boolean出來。雖然Java.lang.Boolean非常簡單,占用的內存也很少,但是一個復雜的類用new創建實例的開銷可能非常大,而且,使用工廠方法可以方便的實現緩存實例,這對客戶端是透明的。所以,能用工廠方法就不要用new。
和Boolean只有兩種狀態不同,Integer也是immutable class,但是狀態上億種,不可能用靜態實例緩存所有狀態。不過,SUN的工程師還是作了一點優化,Integer類緩存了-128到127這256個狀態的Integer,假如使用Integer.valueOf(int i),傳入的int范圍正好在此內,就返回靜態實例。
hashCode()方法很希奇,兩種Boolean的hash code分別是1231和1237。估計寫Boolean.java的人對這兩個數字有非凡偏好:
- public int hashCode() {
- return value ? 1231 : 1237;
- }
equals()方法也很簡單,只有Boolean類型的Object并且value相等才返true:
- public boolean equals(Object obj) {
- if (obj instanceof Boolean) {
- return value == ((Boolean)obj).booleanValue();
- }
- return false;
- }
JDK源碼Java.lang.Boolean的分析就到這里,希望可以在JDK源碼Java.lang.Boolean的基礎上分析其他的代碼,真正掌握JDK。
【編輯推薦】