Java基礎詳解之集合框架工具Collections
說明:Collcetions是集合框架中的工具,特點是方法都是靜態的。
二、Collections中的常見方法1,對list進行二分查找:前提該集合一定要有序。int binarySearch(list,key);//要求list集合中的元素都是Comparable的子類。int binarySearch(list,key,Comparator);2,對list集合進行排序。sort(list);sort(list,comaprator);3,對集合取最大值或者最小值。max(Collection)max(Collection,comparator)min(Collection)min(Collection,comparator)4,對list集合進行反轉。reverse(list);5,對比較方式進行強行逆轉。Comparator reverseOrder();Comparator reverseOrder(Comparator);6,對list集合中的元素進行位置的置換。swap(list,x,y);7,對list集合進行元素的替換。如果被替換的元素不存在,那么原集合不變。replaceAll(list,old,new);三、Aarrays:用于對數組操作的工具類
1,binarySearch(int[]) binarySearch(double[])...2,sort(int[]) sort(char[])....3,toString(int[]).....:將數組變成字符串。4,copyOf();復制數組。5,copyOfRange():復制部分數組。6,equals(int[],int[]);比較兩個數組是否相同。7,List asList(T[]);將數組變成集合。這樣可以通過集合的操作來操作數組中元素,但是不可以使用增刪方法,add,remove。因為數組長度是固定的,會出現UnsupportOperationExcetion??梢允褂玫姆椒ǎ篶ontains,indexOf。。。如果數組中存入的基本數據類型,那么asList會將數組實體作為集合中的元素。如果數組中的存入的應用數據類型,那么asList會將數組中的元素作為集合中的元素。如果想要將集合變數組:可以使用Collection中的toArray方法。傳入指定的類型數組即可,該數組的長度最好為集合的size。四、二分查找過程中的默認比較器
// 在二分查找中設定默認的比較器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); }}五、集合轉化為數組
// 集合變數組// 為什么需要這樣做?為了對元素進行限定操作,不需要進行增刪。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 方法把集合轉換為數組System.out.println(Arrays.toString(arr));//打印內容 }}六、增強for循環
// 增強for循環的出現是為了解決總是使用迭代器方法進行元素提取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的增強for循環,使用entrySet()System.out.println('例子二:HashMap的增強for循環,使用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的增強for循環,使用KeySet()System.out.println('例子三:HashMap的增強for循環,使用KeySet()');Set<Integer> keySet = hm.keySet();for(Integer i : keySet){ System.out.println('Key: '+i+'--- Value:'+hm.get(i));} }}七、關于可變參數的方法
一般的,在java中使用重載的方法應對不同的數據對象,讓它們都可以使用方法,但是還有一種寫法,可以只寫一個方法來接收數據,也不需要建立新的對象。
// 例子一:public class mutilMethod { public static void main(String[] args) {show(1,2,3,4,5); } public static void show(int...a) // 可變參數寫法,數組的特殊值放在開頭 {System.out.println(a.length); }}//例子二:數組有特殊的public class mutilMethod { public static void main(String[] args) {show('字符串',2,3,4,5); // 特殊字符String與int發生組合 } public static void show(String c, int...a) // 可變參數寫法,數組的特殊值放在開頭 {System.out.println(a.length); }}八、關于reverseOrder函數使用
(1)Collections提供的比較器作為新比較器(2)強行逆轉現有比較器
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');// 或者手寫一個自定義比較器,之后使用reverseOrder()函數強行逆轉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); }九、靜態類導入
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. }}
到此這篇關于Java基礎詳解之集合框架工具Collections的文章就介紹到這了,更多相關java集合框架工具Collections內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章: