Java基礎(chǔ)詳解之集合框架工具Collections
說明:Collcetions是集合框架中的工具,特點(diǎn)是方法都是靜態(tài)的。
二、Collections中的常見方法1,對(duì)list進(jìn)行二分查找:前提該集合一定要有序。int binarySearch(list,key);//要求list集合中的元素都是Comparable的子類。int binarySearch(list,key,Comparator);2,對(duì)list集合進(jìn)行排序。sort(list);sort(list,comaprator);3,對(duì)集合取最大值或者最小值。max(Collection)max(Collection,comparator)min(Collection)min(Collection,comparator)4,對(duì)list集合進(jìn)行反轉(zhuǎn)。reverse(list);5,對(duì)比較方式進(jìn)行強(qiáng)行逆轉(zhuǎn)。Comparator reverseOrder();Comparator reverseOrder(Comparator);6,對(duì)list集合中的元素進(jìn)行位置的置換。swap(list,x,y);7,對(duì)list集合進(jìn)行元素的替換。如果被替換的元素不存在,那么原集合不變。replaceAll(list,old,new);三、Aarrays:用于對(duì)數(shù)組操作的工具類
1,binarySearch(int[]) binarySearch(double[])...2,sort(int[]) sort(char[])....3,toString(int[]).....:將數(shù)組變成字符串。4,copyOf();復(fù)制數(shù)組。5,copyOfRange():復(fù)制部分?jǐn)?shù)組。6,equals(int[],int[]);比較兩個(gè)數(shù)組是否相同。7,List asList(T[]);將數(shù)組變成集合。這樣可以通過集合的操作來操作數(shù)組中元素,但是不可以使用增刪方法,add,remove。因?yàn)閿?shù)組長(zhǎng)度是固定的,會(huì)出現(xiàn)UnsupportOperationExcetion??梢允褂玫姆椒ǎ篶ontains,indexOf。。。如果數(shù)組中存入的基本數(shù)據(jù)類型,那么asList會(huì)將數(shù)組實(shí)體作為集合中的元素。如果數(shù)組中的存入的應(yīng)用數(shù)據(jù)類型,那么asList會(huì)將數(shù)組中的元素作為集合中的元素。如果想要將集合變數(shù)組:可以使用Collection中的toArray方法。傳入指定的類型數(shù)組即可,該數(shù)組的長(zhǎng)度最好為集合的size。四、二分查找過程中的默認(rèn)比較器
// 在二分查找中設(shè)定默認(rèn)的比較器import java.util.ArrayList;import java.util.Collections;import java.util.Comparator;import java.util.List;public class binarySerach { public static void main(String[] args) {sortDemo(); } public static void sortDemo() {List<String> list = new ArrayList<String>(); // List集合沒有比較方法list.add('abcd');list.add('aaa');list.add('bbb');list.add('abcdcdc');list.add('z');list.add('zz');list.add('qq');sop('原集合為:'+list);int index = Collections.binarySearch(list,'bbb',new StrLenComparator2());sop('自定義比較器的index: '+index);int index2 = Collections.binarySearch(list,'abcd');sop('不傳入比較器index:'+index2); } public static void sop(Object obj) {System.out.println(obj); }}class StrLenComparator2 implements Comparator<String>{ public int compare(String s1, String s2) {if(s1.length() > s2.length()) return 1;if (s1.length() < s2.length()) return -1;return s1.compareTo(s2); }}五、集合轉(zhuǎn)化為數(shù)組
// 集合變數(shù)組// 為什么需要這樣做?為了對(duì)元素進(jìn)行限定操作,不需要進(jìn)行增刪。import java.lang.reflect.Array;import java.util.ArrayList;import java.util.Arrays;public class CollectionToArray { public static void main(String[] args) {ArrayList<String> al = new ArrayList<String>();al.add('ABC1');al.add('ABC2');al.add('ABC3');al.add('ABC4');al.add('ABC5');System.out.println(al);String[] arr = al.toArray(new String[al.size()]); // toArray 方法把集合轉(zhuǎn)換為數(shù)組System.out.println(Arrays.toString(arr));//打印內(nèi)容 }}六、增強(qiáng)for循環(huán)
// 增強(qiáng)for循環(huán)的出現(xiàn)是為了解決總是使用迭代器方法進(jìn)行元素提取import java.util.ArrayList;import java.util.HashMap;import java.util.Map;import java.util.Set;public class ForEachDemo { public static void main(String[] args) {// 例子一:ArrayList<String> al = new ArrayList<String>();al.add('ABC1');al.add('ABC2');al.add('ABC3');al.add('ABC4');for(String s : al){ System.out.println(s);}//System.out.println(al);// 例子二:HashMap的增強(qiáng)for循環(huán),使用entrySet()System.out.println('例子二:HashMap的增強(qiáng)for循環(huán),使用entrySet()');HashMap<Integer,String> hm = new HashMap<Integer, String>();hm.put(1,'Wzy1');hm.put(2,'Wzy2');hm.put(3,'Wzy3');hm.put(4,'Wzy4');for (Map.Entry<Integer,String> it : hm.entrySet()){ System.out.println('Key: '+it.getKey()+'--- Value:'+it.getValue());}// 例子三:HashMap的增強(qiáng)for循環(huán),使用KeySet()System.out.println('例子三:HashMap的增強(qiáng)for循環(huán),使用KeySet()');Set<Integer> keySet = hm.keySet();for(Integer i : keySet){ System.out.println('Key: '+i+'--- Value:'+hm.get(i));} }}七、關(guān)于可變參數(shù)的方法
一般的,在java中使用重載的方法應(yīng)對(duì)不同的數(shù)據(jù)對(duì)象,讓它們都可以使用方法,但是還有一種寫法,可以只寫一個(gè)方法來接收數(shù)據(jù),也不需要建立新的對(duì)象。
// 例子一:public class mutilMethod { public static void main(String[] args) {show(1,2,3,4,5); } public static void show(int...a) // 可變參數(shù)寫法,數(shù)組的特殊值放在開頭 {System.out.println(a.length); }}//例子二:數(shù)組有特殊的public class mutilMethod { public static void main(String[] args) {show('字符串',2,3,4,5); // 特殊字符String與int發(fā)生組合 } public static void show(String c, int...a) // 可變參數(shù)寫法,數(shù)組的特殊值放在開頭 {System.out.println(a.length); }}八、關(guān)于reverseOrder函數(shù)使用
(1)Collections提供的比較器作為新比較器(2)強(qiáng)行逆轉(zhuǎn)現(xiàn)有比較器
import java.util.*;public class reverseOrder { public static void main(String[] args) {sortDemo(); } public static void sortDemo() {TreeSet<String> ts = new TreeSet<String>(Collections.reverseOrder()); // 傳入reverseOrder()將集合倒序排列ts.add('aaa');// 或者手寫一個(gè)自定義比較器,之后使用reverseOrder()函數(shù)強(qiáng)行逆轉(zhuǎn)ts.add('abc');ts.add('a');ts.add('aa');ts.add('bbb');ts.add('cccc');ts.add('ddddd');ts.add('eeeeee');Iterator it = ts.iterator();while (it.hasNext()){ sop(it.next());} } public static void sop(Object obj) {System.out.println(obj); }九、靜態(tài)類導(dǎo)入
import java.util.*;import static java.util.Arrays.*;import static java.lang.System.*;public class StaticImport extends Object { public static void main(String[] args) {int[] arr = {3,1,5};sort(arr); // 去掉了Arrays.int index = binarySearch(arr,1);// 去掉了Arrays.System.out.println(Arrays.toString(arr)); // 不能去掉Arrays.out.println('index = '+index);// 去掉System. }}
到此這篇關(guān)于Java基礎(chǔ)詳解之集合框架工具Collections的文章就介紹到這了,更多相關(guān)java集合框架工具Collections內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. PHP正則表達(dá)式函數(shù)preg_replace用法實(shí)例分析2. 一個(gè) 2 年 Android 開發(fā)者的 18 條忠告3. vue使用moment如何將時(shí)間戳轉(zhuǎn)為標(biāo)準(zhǔn)日期時(shí)間格式4. js select支持手動(dòng)輸入功能實(shí)現(xiàn)代碼5. Android 實(shí)現(xiàn)徹底退出自己APP 并殺掉所有相關(guān)的進(jìn)程6. Android studio 解決logcat無過濾工具欄的操作7. 什么是Python變量作用域8. vue-drag-chart 拖動(dòng)/縮放圖表組件的實(shí)例代碼9. Spring的異常重試框架Spring Retry簡(jiǎn)單配置操作10. Vue實(shí)現(xiàn)仿iPhone懸浮球的示例代碼
