集合Collection2019-08-16

目的:

學(xué)習(xí)Collection接口的方法與使用,以及Collection抽象接口的子類(lèi)List的ArrayList類(lèi)的方法提佣。

技術(shù):

1.調(diào)用Collection接口的前提:

數(shù)組: 存儲(chǔ)多個(gè)對(duì)象
int[] score = {1,2,3};
int[] score = int int[10];
弊端:數(shù)組長(zhǎng)度不可變 內(nèi)容可變

實(shí)際開(kāi)發(fā)中需要一個(gè)能夠隨時(shí)改變的數(shù)組->集合Collection

 * Collection抽象接口 定義集合的相關(guān)操作
 *         |--List接口 列表 數(shù)組  特點(diǎn):有序  重復(fù)
 *               |--ArrayList
 *               |--LinkedArrayList
 *         |--Set“集合” 特點(diǎn):
 *               |--HasSet
 * Map接口  映射關(guān)系  Key-Value  鍵值對(duì)  健不能相同,值可以相同
 *         |--HashMap
 *         語(yǔ)文 98
 *         英語(yǔ) 98
 *
 * Collections類(lèi)
 *
 * 集合的元素是可變的
 * 添加元素 : add addAll
 * 刪除元素
 * 插入元素
 * 訪(fǎng)問(wèn)元素

2.Cllection接口的調(diào)用:

添加 刪除 獲取

      //Collection接口
        Collection<String> text = new ArrayList<>();
        text.add("Jack");
        text.add("Merry");
        System.out.println(text);

        //刪除一個(gè)對(duì)象
        text.remove("Jack");
        System.out.println(text);

        //獲取元素個(gè)數(shù)
        System.out.println(text.size());

判斷是否包含一個(gè)元素

        if(text.contains("Merry")){
            System.out.println("有Merry");
        }else{
            System.out.println("無(wú)Merry");
        }

        //判斷是否為空
        if(text.isEmpty()){
            System.out.println("是空的");
        }

判斷兩個(gè)集合是否相同 (equals比較集合的內(nèi)容)

        Collection<String> text2 = new ArrayList<>();
        text2.add("Merry");
        text2.add("Jack");

        if(text.equals(text2)){
            System.out.println("兩個(gè)集合相同");
        }else{
            System.out.println("兩個(gè)集合不相同");
        }

清空

        text.clear();
        System.out.println(text);

        System.out.println("----------------");

重點(diǎn) 集合的遍歷 遍歷過(guò)程中不要進(jìn)行插入刪除方法
1.使用Iterator遍歷
hasNext 判斷是否有元
next 獲取下一個(gè)元素
remove 刪除當(dāng)前遍歷過(guò)后的對(duì)象


        Iterator iterator = text2.iterator();

        while(iterator.hasNext()){
            System.out.println(iterator.next());
        }
        System.out.println("----------------");

        //2. for-each 增強(qiáng)的for循環(huán) 快速循環(huán)
        for(String obj :text2){
            System.out.println(obj);
        }

        System.out.println("----------------");
        //3.for-i
        for(int i = 0; i < text2.size(); i++){
            System.out.println(((ArrayList<String>) text2).get(i));
        }

3.List類(lèi)的學(xué)習(xí)與使用:

List接口 extends Collection
1.ArrayList
2.LinkedArrayList 內(nèi)部使用鏈表實(shí)現(xiàn)
ArrayList連續(xù)的內(nèi)存空間 優(yōu)點(diǎn):訪(fǎng)問(wèn)方便 缺點(diǎn):刪除 添加
LinkedArrayList 鏈表不一定連續(xù)(基本不連續(xù)) 優(yōu)點(diǎn):增加 刪除 缺點(diǎn):訪(fǎng)問(wèn)
集合里面只能存放對(duì)象
byte char long int float double boolean ArrayList<>括號(hào)里面不能是基本數(shù)據(jù)類(lèi)型
包裝類(lèi)
Byte Char Int Long Float Double Boolean
自動(dòng)將基本數(shù)據(jù)類(lèi)型轉(zhuǎn)化為對(duì)于包裝類(lèi)

添加 訪(fǎng)問(wèn) 修改 插入

ArrayList<Integer> score = new ArrayList<>();
        score.add(2);        //在末尾添加
        score.add(3);
        
        score.add(0,1);//在指定位置插入
        System.out.println(score);

        //訪(fǎng)問(wèn)指定元素
        score.get(1);

        //修改一個(gè)元素
        score.set(2,4);

刪除

        //刪除指定元素
        score.remove(0);
        System.out.println(score);

        //刪除指定對(duì)象
        score.remove((Integer)2);
        System.out.println(score);

        score.clear();//刪除所有 清空
        System.out.println(score);

        ArrayList<Integer> a2 = new ArrayList<>();
        a2.add(5);
        a2.add(6);
        a2.add(7);

將一個(gè)集合的內(nèi)容添加到當(dāng)前集合中 取交集

        score.addAll(a2);
        System.out.println(score);

        ArrayList<Integer> a3 = new ArrayList<>();
        a3.add(1);
        a3.add(2);
        a3.add(3);
        a3.add(4);
        a3.add(5);
        score.retainAll(a3); //取交集
        System.out.println(score);

訪(fǎng)問(wèn)某個(gè)集合里面元素的位置/索引值

        ArrayList<Integer> a4 = new ArrayList<>();
        a4.add(1);
        a4.add(2);
        a4.add(2);
        a4.add(1);

        System.out.println(a4.indexOf(1));//第一次出現(xiàn)的位置
        System.out.println(a4.lastIndexOf(1));//最后一次出現(xiàn)的位置

將ArrayList轉(zhuǎn)化為普通數(shù)組

        //1.
        Object[] objects = a4.toArray();//為什么這么做:讓a4轉(zhuǎn)為不可變的
        for(Object i:objects){
            System.out.println(i);
        }
        System.out.println("-------------------");
        //2.
        Integer[] objects2 = new Integer[a4.size()];
        a4.toArray(objects2);
        for(Integer i:objects2){
            System.out.println(i);
        }

獲取集合某個(gè)范圍的子集合

        List<Integer> intederList =  a4.subList(1,3); // 1到2,不包括3所對(duì)應(yīng)的元素
        System.out.println(intederList);

刪除某個(gè)范圍內(nèi)的元素


        ArrayList<Integer> nums = new ArrayList<>();
        nums.add(1);
        nums.add(2);
        nums.add(3);
        nums.add(4);

        //Lambda表達(dá)式
        nums.removeIf(obj -> obj % 2 == 0);

        System.out.println(nums);
        // or

        for(int i = 0; i < nums.size(); i++){
            Integer obj = nums.get(i);
            if(obj % 2 == 0){
                nums.remove(i);
                  i--;
            }
        }
        System.out.println(nums);
閉包:

閉包 enclusure 把函數(shù)作為一個(gè)方法的參數(shù)
定義一個(gè)ArrayClass類(lèi)缤削,其中定義一個(gè)方法,方法參數(shù)為一個(gè)整形數(shù)組和一個(gè)接口對(duì)象

class ArrayClass{
    public void test(int[] target, Show s){
        for (int element: target){
            s.customShow(element);
        }
    }
}

//必須是接口 這個(gè)接口里面只有一個(gè)方法
interface Show{
    void customShow(int element);
}

class PXDClass implements Show{
    @Override
    public void customShow(int element) {
        System.out.println(element);
    }
}

調(diào)用:
1.使用方式: 定義一個(gè)類(lèi)實(shí)現(xiàn)接口

       
        ArrayClass ac = new ArrayClass();
        int[] num = {1,2,3,4,5,6};
        PXDClass pc = new PXDClass();
        ac.test(num, pc);

2.使用匿名類(lèi)

        ArrayClass ac = new ArrayClass();
        int[] num = {1,2,3,4,5,6};
        ac.test(num, new Show() {
            @Override
            public void customShow(int element) {
                System.out.println(element);
            }
        });
  1. 使用Lambda表達(dá)式
        //如果參數(shù)是一個(gè)接口類(lèi)對(duì)象吹榴,且接口里面只有一個(gè)方法
        //把這個(gè)方法作為參數(shù)傳遞過(guò)去 可以省略方法名
        ArrayClass ac = new ArrayClass();
        int[] num = {1,2,3,4,5,6};
        ac.test(num, (int element) -> {
            System.out.println(element);
        });

4.如果只有一個(gè)參數(shù) 參數(shù)類(lèi)型可以省略

        ArrayClass ac = new ArrayClass();
        int[] num = {1,2,3,4,5,6};
        ac.test(num,element -> {
            System.out.println(element);
        });

5.如果代碼塊里面只有一行語(yǔ)句 大括號(hào)可以省略

        ArrayClass ac = new ArrayClass();
        int[] num = {1,2,3,4,5,6};
        ac.test(num,element -> System.out.println(element));
排序 sort:
1.對(duì)整形數(shù)組排序:
//排序 sort
          ArrayList<Integer> a1 = new ArrayList<>();
          a1.add(2);
          a1.add(1);
          a1.add(4);
          a1.add(3);

//          //方法1.系統(tǒng)提供
//          a1.sort(Comparator.comparing(Integer::intValue));

//        //方法2.
//        a1.sort( new PXDCompara());

//        //方法3匿名
//        a1.sort(new Comparator<Integer>() {
//            @Override
//            public int compare(Integer integer, Integer t1) {
//                return integer - t1;
//            }
//        });

//        //方法4.化簡(jiǎn)
//        a1.sort((Integer integer, Integer t1)->{
//            return integer - t1;
//        });
        System.out.println(a1);

方法2的PSDCompare類(lèi):

class PXDCompara implements Comparator{
    //什么時(shí)候需要自己手動(dòng)創(chuàng)建比較器
    //如果系統(tǒng)默認(rèn)提供的方法不能完成我們的需求
    @Override
    public int compare(Object o, Object t1) {
        int mo = (int)0;
        int mt1 = (int)t1;
        return mo - mt1;
    }
}
2.對(duì)象排序:
//對(duì)象排序
        List<Person> list = new ArrayList<>();

        Person person1 = new Person("jack",20);
        Person person2 = new Person("rose",30);
        Person person3 = new Person("jack",30);

        list.add(person1);
        list.add(person2);
        list.add(person3);


        //進(jìn)行排序
        //系統(tǒng)提供 按年齡排序
        //list.sort(Comparator.comparing(Person::getAge));

        //自己編寫(xiě) 先按年齡 再比姓名
        list.sort((Person p1 , Person p2) -> {
            if(p1.getAge()  != p2.getAge()){
                return p1.getAge() - p2.getAge();
            }else{
                return p1.getName().compareTo(p2.getName());
            }
        });
        System.out.println(list);

提供的·Person類(lèi):

class Person {
    public String name;
    public int age;

    public Person(String name, int age){
        this.age = age;
        this.name = name;
    }

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}

實(shí)際編程:

編程一:

  • 創(chuàng)建一個(gè)Person: name age屬性
  • 創(chuàng)建ArrayList對(duì)象保存多個(gè)Person對(duì)象
  • 1.統(tǒng)計(jì)年齡大于30的人數(shù)
  • 2.統(tǒng)計(jì)姓張的人數(shù)
1.定義Person類(lèi):
public class Person {
    public String name;
    public int age;

    public Person(String name, int age){
        this.age = age;
        this.name = name;
    }
}
2.進(jìn)行操作:
import java.util.ArrayList;

public class Myclass {
   public static void main(String[] args){
       ArrayList<Person> people = new ArrayList<>();

       Person person1 = new Person("wuxia",18);
       Person person2 = new Person("liyuan",30);
       Person person3 = new Person("wangwu",21);
       Person person4 = new Person("lisi",34);
       Person person5 = new Person("zhangsan",25);

/*

       people.add(person1);
       people.add(person2);
       people.add(person3);
       people.add(person4);
       people.add(person5);

       int countA = 0;

       people.removeIf(obj -> obj.age < 30);
       for(Person person : people){
           countA++;
       }
       System.out.println(countA);

       people.clear();

       people.add(person1);
       people.add(person2);
       people.add(person3);
       people.add(person4);
       people.add(person5);

       int countB = 0;
       int count = people.size();

       people.removeIf(obj -> obj.name.contains("zhang"));
       for(Person person : people){
           countB++;
       }
       System.out.println(count-countB);

*/
       people.add(person1);
       people.add(person2);
       people.add(person3);
       people.add(person4);
       people.add(person5);

       int ageCount = 0;
       int zhangCount = 0;

       for(Person person : people){
           if(person.age >= 30){
               ageCount++;
           }
           if(person.name.contains("zhang")){
               zhangCount++;
           }
       }
      System.out.println(ageCount);
      System.out.println(zhangCount);
   }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末亭敢,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子图筹,更是在濱河造成了極大的恐慌帅刀,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,997評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件远剩,死亡現(xiàn)場(chǎng)離奇詭異扣溺,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)民宿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)娇妓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人活鹰,你說(shuō)我怎么就攤上這事哈恰。” “怎么了志群?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,359評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵着绷,是天一觀(guān)的道長(zhǎng)。 經(jīng)常有香客問(wèn)我锌云,道長(zhǎng)荠医,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,309評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮彬向,結(jié)果婚禮上兼贡,老公的妹妹穿的比我還像新娘。我一直安慰自己娃胆,他們只是感情好遍希,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著里烦,像睡著了一般凿蒜。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上胁黑,一...
    開(kāi)封第一講書(shū)人閱讀 51,258評(píng)論 1 300
  • 那天废封,我揣著相機(jī)與錄音,去河邊找鬼丧蘸。 笑死漂洋,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的力喷。 我是一名探鬼主播氮发,決...
    沈念sama閱讀 40,122評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼冗懦!你這毒婦竟也來(lái)了爽冕?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,970評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤披蕉,失蹤者是張志新(化名)和其女友劉穎颈畸,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體没讲,經(jīng)...
    沈念sama閱讀 45,403評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡眯娱,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了爬凑。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片徙缴。...
    茶點(diǎn)故事閱讀 39,769評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖嘁信,靈堂內(nèi)的尸體忽然破棺而出于样,到底是詐尸還是另有隱情,我是刑警寧澤潘靖,帶...
    沈念sama閱讀 35,464評(píng)論 5 344
  • 正文 年R本政府宣布穿剖,位于F島的核電站,受9級(jí)特大地震影響卦溢,放射性物質(zhì)發(fā)生泄漏糊余。R本人自食惡果不足惜秀又,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望贬芥。 院中可真熱鬧吐辙,春花似錦、人聲如沸蘸劈。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,705評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)昵时。三九已至,卻和暖如春椒丧,著一層夾襖步出監(jiān)牢的瞬間壹甥,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,848評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工壶熏, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留句柠,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,831評(píng)論 2 370
  • 正文 我出身青樓棒假,卻偏偏與公主長(zhǎng)得像溯职,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子帽哑,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評(píng)論 2 354

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

  • 四谜酒、集合框架 1:String類(lèi):字符串(重點(diǎn)) (1)多個(gè)字符組成的一個(gè)序列,叫字符串妻枕。生活中很多數(shù)據(jù)的描述都采...
    佘大將軍閱讀 752評(píng)論 0 2
  • 一僻族、基礎(chǔ)知識(shí):1、JVM屡谐、JRE和JDK的區(qū)別:JVM(Java Virtual Machine):java虛擬機(jī)...
    殺小賊閱讀 2,378評(píng)論 0 4
  • ? 在編寫(xiě)java程序中述么,我們最常用的除了八種基本數(shù)據(jù)類(lèi)型,String對(duì)象外還有一個(gè)集合類(lèi)愕掏,在我們的的程序中到處...
    Java幫幫閱讀 1,420評(píng)論 0 6
  • Java集合類(lèi)可用于存儲(chǔ)數(shù)量不等的對(duì)象,并可以實(shí)現(xiàn)常用的數(shù)據(jù)結(jié)構(gòu)如棧,隊(duì)列等,Java集合還可以用于保存具有映射關(guān)...
    小徐andorid閱讀 1,939評(píng)論 0 13
  • 概要 上一章度秘,我們學(xué)習(xí)了Collection的架構(gòu)。這一章開(kāi)始饵撑,我們對(duì)Collection的具體實(shí)現(xiàn)類(lèi)進(jìn)行講解剑梳;首...
    廢棄的root閱讀 892評(píng)論 0 4