Map<String,Integer> a=new HashMap(),b=new HashMap();
a.put("a", 100);
b.put("a", 100);
a.put("c", 130);
b.put("c", 130);
System.out.println(a.get("a")==b.get("a"));//false
System.out.println(a.get("c")==b.get("c"));//true
System.out.println((Integer)130==130);//true
System.out.println((Integer)100==100);
在放入map的時候,自動將int 130轉成了Integer,取出來的時候也是Integer,而Integer的==是判斷引用等價性,
當如果整型字面量的值在-128到127之間,那么不會new新的Integer對象,而是直接引用常量池中的Integer對象
所以System.out.println(a.get("c")==b.get("c"));//true
而大于130,new 了新的Integer,System.out.println(a.get("a")==b.get("a"));//false
所以所有相同類型的包裝類對象之間值得比較,全部使用equals方法。
有poJAVA源碼參考的博客https://blog.csdn.net/so_geili/article/details/79720238
其實同樣的原理,而且實現的更精巧的(不只是一定范圍,而是所有)的是String constant pool
String s1 ="java";
String s2 = "java";
String s3 = new String("java");
System.out.println(s1==s2); //true
System.out.println(s1==s3); //false
當我們新建String對象的時候,JVM會先檢查string常量池,如果已經有同樣字符串存在里面,那就取出它的引用,如果不存在,就在pool里面新建一個對象
這樣做的原因是在Java里面new的代價是很高的,而且不用之后又馬上回收增加GC垃圾回收 的負擔,所以要盡量減少new操作。雖然這只是一個很小的點,平時可以不注意,但是如果寫很大的程序,積少成多。
浙公網安備 33010602011771號