Java中l(wèi)ist集合的clear方法及空字符串的區(qū)別
1、list集合的clear方法
在使用list 結合的時候習慣了 list=null ;
在創(chuàng)建這樣的方式,但是發(fā)現(xiàn)使用list的clear 方法很不錯,尤其是有大量循環(huán)的時候 list.clear()與list = null 區(qū)別 java中l(wèi)ist集合通過clear()方法清空,只會將list中的對象變成垃圾回收清空,但是list對象還是存在
但是通過list=null后,不僅列表中的對象變成了垃圾,為列表分配的空間也會回收,什么都不做與賦值NULL一樣, 說明直到程序結束也用不上列表list了,它自然就成為垃圾了.clear()只是清除了對象的引用,使那些對象成為垃圾
ArrayList.clear、=null、new Arraylist之間的對比區(qū)別
1.使用ArrayList的對象方法clear()
List list = new ArrayList(); List list1 = list; list.add(1); list.add(2); list.add(3); list.clear();
ArrayList對象內部維護一個對象數(shù)組elementData, 當執(zhí)行clear()方法時, 會執(zhí)行循環(huán)將elementData中每一個坐標都設置為為null, 并設置數(shù)組的size為0;我們還可以使用該list進行操作
clear源碼如下
public void clear() { modCount++; // clear to let GC do its work for (int i = 0; i < size; i++) elementData[i] = null; size = 0; }
2.使用=null
ArrayList<String> list = new ArrayList<String>(); list.add("0"); list.add("1"); list.add("2"); list = null;
直接將變量list指向null,通常當我們不需要再使用ArrayList對象時,可以將變量值設為null,以便GC可以運作并回收這部分內存空間。
需要注意的是當仍有其他變量指向該對象時,即使講變量list置為null垃圾回收器也無法回收該內存空間。如下:
ArrayList<String> list = new ArrayList<String>(); ArrayList<String> arraylist = list; list.add("0"); list.add("1"); list.add("2"); list = null; // 此時list變量指向null,而arraylist變量仍然指向原內存空間,原內存空間得不到釋放
使用= new ArrayList() 方法3有點類似于方法1,都是得到一個空的ArrayList對象。
不過new ArrayList()會得到一個初始化內部數(shù)組elementData容量為10的ArrayList對象,而方法1得到的對象的容量與原對象一致。值得注意的是使用方法3需要進行如在內存中重新開辟內存空間等操作,開銷較大,如果只是單純的想要使用空的ArrayList對象,建議使用方法1,相對來說可盡量避免堆內存溢出問題。
2、null、與""的區(qū)別
問題一
null、與""的區(qū)別
null是沒有地址 ““是有地址但是里面的內容是空的 null和”“的區(qū)別 String s=null; string.trim()就會拋出為空的exception String s=””; string.trim()就不會拋,為什么? 答: NULL代表聲明了一個空對象,根本就不是一個字符串。 ""代表聲明了一個對象實例,這個對象實例的值是一個長度為0的空字符串。
NULL代表聲明了一個空對象,對空對象做任何操作都不行的,除了=和== ""是一個字符串了,只是這個字符串里面沒有內容了
String s=null;只是定義了一個句柄,也就是說你有了個引用,但是這個引用未指向任何內存空間 String s=“”;這個引用已經指向了一塊是空字符串的內存空間,是一個實際的東東了,所以你可以對它操作,而不用擔心什么了
你說數(shù)字0和沒有是不是一種概念????道理一樣的
而且,null可以賦值給任何對象.""就不行了.
這里""和NULL絕對是兩個概念 ""代表一個字符串存在,它的值就是“” NULL代表字符串根本沒有實際的值,你并不知道它是什么。。。
哦,我明白了,意思就是String string = null 跟String string;是一回事兒
null是空對象 ““是空字符串 String s=null;//null是未分配堆內存空間 String a;//分配了一個內存空間,沒存入任何對象 String a=””;//分配了一個內存空間,存了一個字符串對象
問題二
String s;和String s=null;和String s=“a”;有什么區(qū)別?
針對這三種情況,使用out.println(s);的時候,第一個會出現(xiàn)異常,第二個會輸出null.第三個則會輸出a. 這是為什么呢?這三句聲明語句,各自作了什么呢?
答: 第一個只是定義了一個String類型變量s,并沒有給它賦初值,在Java中,默認在使用一個變量的時候必須賦予它初值(降低風險)。
第二個和第三個都定義了String類型變量s,并賦予它初值,只不過第二個賦予的值為null(空)罷了
主要要理解的是String s; s為一個引用~~它不是對象 第一個是沒有初始化的引用; 第二個為空引用; 第三個是在字符串池里寫入一個字符’a’,然后用s指向它。 另外, String s="a"和String s=new String(“a”);是有本質上的區(qū)別的 前者是在字符串池里寫入一個字符’a’,然后用s指向它; 后者是在堆上創(chuàng)建一個內容為"a"的字符串對象。 String str=“aaa”; //于棧上分配內存 String str=new String(“aaa”); //于堆上分配內存
String s; 系統(tǒng)會自動賦值null
String s;只是給s分配一個內存空間 String s=null;是分配的空間中存儲的值為空值 String s=“a”;這句就不用我多說了分配的空間的值為字符a
問題三
聲明了一個string a;變量 在以后的判斷中,a==""和a==null有何不同?
答: 如果沒有給a賦過值,a==““會導致異常。 在實際處理時,往往認為”“和null代表相同的含義,即都代表無值。
此時建議用如下語法: if(anull || a””) { } 如果a為null,就不會執(zhí)行后面的判斷,直接返回true。
null是用來判斷引用類型是否分配了存儲空間 ““是針對字符串的; string類型實際上是字符串指針,也即是一個引用類型 所以如果沒有給a賦過值,a==”“會導致異常 所以if(anull || a””){}這種寫法也是正確的
問題四
String abc=null;String abc=“”;String abc;三種寫法有什么區(qū)別?
答:
1:創(chuàng)建一個空字符串對象
2:創(chuàng)建一個字符串為空的字符串對象。
3:聲明一個字符串對象,但并沒有分配內存,而1,2已經分配了內存 對于最后一種表示,你不能if(abc==null),或者int length = abc.length();編譯的時候會提示可能沒有初始化.
String abc=null; String abc=“”; 一般推薦使用第二種 第一種abc指向null,很多時候要判斷字符串是否為空時,容易漏掉這種情況,在調用String的相關方法的時候就會出錯 第二種則相對簡單,String的方法都可以用,判斷的時候也不會出錯
String abc=null; String abc; String a=""; String b=""; String c=new String(""); String d=new String(""); //1)等于2),和C語言不同,JAVA為安全原因不允許一個懸掛引用,沒有賦值的引用地址一律自動賦值為NULL,以防止訪問到任意內存 //3)和4)中,變量a和b將會指向同一內存地址(""的地址) //5)和6)中,變量c和d不會指向同一地址,而是兩個""內容的地址,并且和a,b不同,實際上,3)和4)相當于new String("").intern(). //String類維護著一個字符串池,對于像3)和4)這樣的賦值方法,String會在這個池中查找字符串是否已經在池中,如果在,就直接指向該地址,
如果不在,生成一個實例放入池中再指向那個地址,可見對于同樣內容的字符串多次引用時3)4)的方法要比5)6)的方法剩內存,之所以這樣做,是
因為String是一個內容不可變的量,運用的是設計模式GOF.FlyWeight
但有個關鍵的一點,沒有人說到,這就是: String s;在什么情況下可以等同于String s=null;而在什么情況下又不等同?! 考慮下面的代碼:
public class StringTest { static String s; //* public static void main(String[] args) { //String s; //** System.out.println(s); } }
編譯并運行上面的代碼,將打印null。 可見標有*號的行是自動初始化了的(s被自動初始化為null)。
而如果把標有**號的行取消注釋,代碼將不能通過編譯,這是因為這行定義的是本地變量,而本地變量是不會自動初始化的。
由此得出結論: 在成員變量的定義中,String s;等同于String s=null; 而在本地變量(方法變量)的定義中,String s;不等同于String s=null;,這時要使用s必須顯式地賦值。
這些雖然是小知識點,但在實際應用中很重要,也很容易被一些人忽視,特此提出。
還有一點要說明的是: 只要是在方法在中定義變量都要顯示賦初值,main()方法也不例外,而在方法之外編譯器回自動賦初值。
到此這篇關于Java中l(wèi)ist集合的clear方法及空字符串的區(qū)別的文章就介紹到這了,更多相關list集合的clear方法及空字符內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
java線程之Happens before規(guī)則案例詳解
這篇文章主要為大家介紹了java線程之Happens-before規(guī)則,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪<BR>2022-08-08Security中的WebSecurityConfigurerAdapter詳解
這篇文章主要介紹了Security中的WebSecurityConfigurerAdapter詳解,今天我們要進一步的的學習如何自定義配置Spring?Security,本文結合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2023-07-07