來源:博為峰51Code軟件開發(fā) 2018-06-12 17:06:09
例如:
for(int i=0;i<list.size();i++){< p="">
System.out.println(i);
}
可以修改為:
for(int i=0,size=list.size();i<size;i++){< p="">
System.out.println(i);
}
4、常量的定義可以放到接口中
在Java中,接口里只允許存在常量,因此把常量放到接口中聲明就可以省去public static final這幾個關鍵詞。
5、ArrayList和LinkedList的選擇
這個問題比較常見。通常程序員最好能夠對list的使用場景做出評估,然后根據特性作出選擇。
ArrayList底層是使用數(shù)組實現(xiàn)的,因此隨機讀取數(shù)據會比LinkedList快很多,而LinkedList是使用鏈表實現(xiàn)的,新增和刪除數(shù)據的速度比ArrayList快不少。
6、String,StringBuffer和StringBuilder
這個問題也比較常見。在進行字符串拼接處理的時候,String通常會產生多個對象,而且將多個值緩存到常量池中。
例如:
String a=“a”;
String b=“b”;
a=a+b;
這種情況下jvm會產生“a”,“b”,“ab”三個對象。而且字符串拼接的性能也很低。因此通常需要做字符串處理的時候盡量采用StringBuffer和StringBuilder來。
7、包裝類和基本類型的選擇
在代碼中,如果可以使用基本數(shù)據類型來做局部變量類型的話盡量使用基本數(shù)據類型,因為基本類型的變量是存放在棧中的,包裝類的變量是在堆中,棧的操作速度比堆快很多。
8、盡早的將不再使用的變量引用賦給null
這樣做可以幫助jvm更快的進行內存回收。當然很多人其實對這種做法并不感冒。
9、在finally塊中對資源進行釋放
典型的場景是使用io流的時候,不論是否出現(xiàn)異常最后都應該在finally中對流進行關閉。
10、在HashMap中使用一個Object作為key時要注意如何區(qū)分Object是否相同
在jdk的HashMap實現(xiàn)中,判斷兩個Object類型的key是否相同的標準是hashcode是否相同和equals方法的返回值。如果業(yè)務上需要對兩個數(shù)據相同的內存對象當作不同的key存儲到hashmap中就要對hashcode和equals方法進行覆蓋。
Java描述復雜數(shù)據結構的主要方式是集合框架。Java沒有指針,而是通過強大的集合框架描述數(shù)組、對象數(shù)組等復雜的數(shù)據結構。學好這些數(shù)據結構的描述方法對于應用程序編寫,特別是涉及到服務器方、3層結構編程至關重要。程序員在這個時候不能再用諸如數(shù)據庫結果集之類的結構描述數(shù)據了。
由于很多語言沒有這么強大的集合框架體系,很多初學者不知所措,更不知道拿來做什么用,因此應該引起足夠的重視。
相關推薦:
小升初試題、期中期末題、小學奧數(shù)題
盡在奧數(shù)網公眾號
歡迎使用手機、平板等移動設備訪問幼教網,幼兒教育我們一路陪伴同行!>>點擊查看