java Collections和Arrays工具類

一集合的工具類(Collections):
筆試題:

說出Collection與Collections的區(qū)別?
1.Collection是一個(gè)單列集合跟接口,Collections是一個(gè)操作集合的工具類

Collections常見方法:

對(duì)list集合排序

sort(list);
sort(list,comparator)

對(duì)list進(jìn)行二分法查找

int binarySearch(list,key);
int binarySearch(list,key,Comparator);

按照指定比較器進(jìn)行排序

 max(Collection);
 max(Collection,comparator);
 min(Collection);
 min(Collection,comparator);

*對(duì)list集合進(jìn)行反轉(zhuǎn) *

 reverse(list);

將不同步的集合變?yōu)橥降募?/em>

 Set synchronizedSet(SET<t> s)
 Map synchronizedMaP(Map<K,V> m)
 List synchronizedList(List<T> list)
public class Test {
    public static void main(String args[]){
        ArrayList <Integer> list = new ArrayList<Integer>();
        list.add(1);
        list.add(123);
        list.add(3);
        list.add(12);
        list.add(23);
        
        //排序
        Collections.sort(list);
        System.out.println("排序后元素為:"+list);
        
        //查找
        System.out.println("找到的位置是:"+Collections.binarySearch(list, 123));
        
        //最大值
        System.out.println("最大值是:"+Collections.max(list));
        
        //反轉(zhuǎn)
        Collections.reverse(list);
        System.out.println("反轉(zhuǎn)后無素為:"+list);
    }   
}
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;

class Student{
    int id;
    String name;
    public Student(int id,String name){
        this.id = id;
        this.name = name;
    }
    
    @Override
    public String toString() {
        // TODO Auto-generated method stub
        return String.format("編號(hào):%d 姓名:%s\n",id,name);
    }
}

class MyComparator implements Comparator<Student>{
    @Override
    public int compare(Student o1, Student o2) {
        return o1.id - o2.id;
    }
}

public class Demo02 {

    public static void main(String[] args) {
        ArrayList <Student> list = new ArrayList<Student> ();
        list.add(new Student(3,"丁昌江"));
        list.add(new Student(2,"熊尚旭"));
        list.add(new Student(1,"吳云飛"));
        
        //排序
        Collections.sort(list,new MyComparator());
        System.out.println("排序后元素為:"+list);
        
        //查找
        System.out.println("查找到的位置是:"+Collections.binarySearch(list,new Student(1,"馬云"),new MyComparator()));
        /*因?yàn)楸容^器的原因,只要編號(hào)一樣就視為找到了*/
        
        //反轉(zhuǎn)
        Collections.reverse(list);//反轉(zhuǎn)是不依賴比較器的喲!
        System.out.println("反轉(zhuǎn)后無素為:"+list);
        
    }
}
二:集合的工具類Arrays:
Arrays常見方法:

二分查找:

binarySearch(int[]);
binarySearch(double[]);

數(shù)組排序

sort(int [])
sort(char[])

將數(shù)組變成字符串

toString(int []);

復(fù)制數(shù)組

copyOf(int/boolean...[] original,int newLength);
    original:源數(shù)組
    newLenght:新數(shù)組長度

復(fù)制部分?jǐn)?shù)組

copyOfRange(int/float[]... original, int from, int to)

比較兩個(gè)數(shù)組是否相同

equals(int[],int[]);

將數(shù)組變成集合

List asList(T[]);
public class Test02 {

    public static void main(String[] args) {
        int a[] = {1,3,2,6};
        int b[] = Arrays.copyOf(a,4);
        int c[] = Arrays.copyOfRange(a, 1, 4);
        
        System.out.println(Arrays.toString(b));
        System.out.println(Arrays.toString(c));
        
        System.out.println("比較兩個(gè)數(shù)組:"+Arrays.equals(a, b));//true
        /*兩個(gè)數(shù)組的比較,只有內(nèi)容,容量,順序一樣才是true*/
        
        Integer[] d1= {1,2,3,4};
        List list = Arrays.asList(d1);
        for (int i = 0; i < list.size();i++){
            System.out.println(list.get(i)+"");
        }
        /*
            這里如果接收的是基本數(shù)據(jù)類型的數(shù)組,那么相當(dāng)于只是存儲(chǔ)了int[]這個(gè)類型,容量是1
            一般是使用包裝類Integer
         */
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • Java 語言支持的類型分為兩類:基本類型和引用類型。整型(byte 1, short 2, int 4, lon...
    xiaogmail閱讀 1,369評(píng)論 0 10
  • 1.Java集合框架是什么?說出一些集合框架的優(yōu)點(diǎn)? 每種編程語言中都有集合,最初的Java版本包含幾種集合類:V...
    獨(dú)念白閱讀 823評(píng)論 0 2
  • java筆記第一天 == 和 equals ==比較的比較的是兩個(gè)變量的值是否相等,對(duì)于引用型變量表示的是兩個(gè)變量...
    jmychou閱讀 1,525評(píng)論 0 3
  • 1. Collections工具類 1.1 Collections類概述 針對(duì)集合操作 的工具類,里面的方法都是靜...
    JackChen1024閱讀 251評(píng)論 0 0
  • 今天,來北京整整一年。 去年的今天北京也下著雨,下了火車頂著大雨匆匆上了地鐵,稀里糊涂花200塊找了個(gè)住的地方,那...
    猛哥不小心閱讀 272評(píng)論 5 0