亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

Java基礎(chǔ)詳解之集合框架工具Collections

瀏覽:3日期:2022-08-13 17:01:54
一、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)!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 久久综合久久久久 | 国产视频福利在线 | 欧美 日韩 中字 国产 | 免费看大片的 | 欧美日韩一区在线观看 | 色播在线播放 | 黄色一及 | 加勒比一本大道香蕉在线视频 | 特黄一级真人毛片 | 青青青国产依人免费视频 | 亚洲乱码国产乱码精品精98 | 三级毛片在线看 | 香蕉精品在线 | 美女天堂网 | 99精品久久秒播无毒不卡 | 五月天婷色 | 国内不卡1区2区 | 国产成人啪精品 | 一级毛片一级毛片一级毛片 | 国产精品色综合久久 | 不卡国产视频 | 欧美成人丝袜一区二区 | 美女白丝超短裙被输出动态图 | 国产三级全黄 | 在线观看免费国产视频 | 伊人久久精品成人网 | 成人午夜大片免费7777 | 香蕉视频在线网址 | 精品香蕉伊思人在线观看 | 美女制服一二三区 | 亚洲国产第一区二区香蕉日日 | 国亚洲欧美日韩精品 | 福利视频在线看 | 国产主播专区 | 亚洲一成人毛片 | 中文字幕电影在线观看 | 国产亚洲精品美女久久久久 | 最新69成人精品毛片 | 69成人做爰免费视频 | 狠狠五月天 | 亚洲欧美日韩中文不卡 |