3.4 Java 中的集合框架(上)(常用工具类)

1、Java中的集合框架概述

集合框架、

  • 概念与作用
    Java中的集合类:是一种工具类,就像是容器,存储任意数量的具有共同属性的对象
    集合的作用:
    1、在类的内部,对数据进行组织;
    2、简单而快速的搜索大数量的条目;
    3、有的集合接口,提供了一系列排列有序的元素,并且可以在序列中间快速的插入或者删除有关元素;
    4、有的集合接口,提供了映射关系,可以通过关键字key去快速查找到对应的唯一对象,而这个关键字可以是任意类型
    与数组的对比--为何选择集合而不是数组
    1、数组的长度固定,集合长度可变
    2、数组只能通过下标访问元素,类型固定,而有的集合可以通过任意类型查找所映射的具体对象

  • 体系结构
    Java集合框架
    1、Collection
    List序列:存储结构排列有序,可重复---ArrayList、LinkedList
    Queue队列:存储结构排列有序,可重复---LinkedList
    Set集:存储结构排列无序,不可重复---HashSet
    2、Map<以Key、Value两个对象为映射存储数据>---HashMap

  • 实际应用

2、Collection接口&List接口简介

  • Collection接口
    是List、Set和Queue接口的父接口
    定义了可用于操作List、Set和Queue的方法---增删改查
    1、List是元素有序并且可以重复的集合,被称为序列
    2、List可以精确的控制每个元素插入的位置,或删除某个位置元素
    3、ArrayList--数组序列,是List的一个重要实现类
    4、ArrayList底层是由数组实现的

3、学生选课-创建学生类和课程类

  • 实现功能---模拟学生选课功能

  • 选择课程(往集合中添加课程)
  • 删除所选的某门课程(删除集合中的元素)
  • 查看所选课程
  • 修改所选课程
package com.imooc.student;

import java.util.HashSet;
import java.util.Set;
/**
 * 学生类
 * @author bzz
 *
 */
public class Student {
    public String id;
    public String name;
    public Set courses;      //存储成绩信息
    public Student(String id,String name){
        this.id=id;
        this.name=name;
        this.courses=new HashSet();
    }
}
package com.imooc.student;
/**
 * 课程类
 * @author bzz
 *
 */
public class Course {
    public String id;
    /**
     * 实际开发中应当把所有属性私有化
     * private String id;
     * public String getId(){
     *      return id;
     * public void setId(String id){
     *      this.id=id;
     * }
     */
    
    public String name;
    public Course(String id,String name){
        this.id=id;
        this.name=name;
    }
}

4、学生选课-添加课程

package com.imooc.student;

import java.util.Arrays;
import java.util.List;
import java.util.ArrayList;
/**
 * 备选课程类
 * @author bzz
 *
 */
public class ListTest {
    public List coursesToSelect;//用于存放备选课程的List
    public ListTest(){
        this.coursesToSelect=new ArrayList();
    }
    // 用于往courseToSelect中添加备选课程

    public void testAdd(){
        //创建一个课程对象,并通过调用add,添加到备选课程List中

        Course cr1=new Course("1","数据结构");
        coursesToSelect.add(cr1);
        //对象存入集合都变成Object类型,去除时需要类型转换
        Course temp=(Course) coursesToSelect.get(0);
        System.out.println("添加了课程:"+temp.id+":"+temp.name);

        Course cr2=new Course("2","C语言");
        coursesToSelect.add(0,cr2);
        Course temp2=(Course) coursesToSelect.get(0);
        System.out.println("添加了课程:"+temp2.id+":"+temp2.name);
        
//      以下方法会抛出数组下标越界异常
//      Course cr3=new Course("3","test");
//      coursesToSelect.add(4,cr3);  
        
        Course[] course={new Course("3","离散数学"),new Course("4","汇编语言")};
        coursesToSelect.addAll(Arrays.asList(course));
        Course temp3=(Course) coursesToSelect.get(2);
        Course temp4=(Course) coursesToSelect.get(3);
        System.out.println("添加了两门课程"+temp3.id+":"+temp3.name+temp4.id+":"+temp4.name);
        
        Course[] course2={new Course("5","高等数学"),new Course("5","大学英语")};
        coursesToSelect.addAll(2,Arrays.asList(course2));
        Course temp5=(Course) coursesToSelect.get(2);
        Course temp6=(Course) coursesToSelect.get(3);
        System.out.println("添加了两门课程"+temp5.id+":"+temp5.name+temp6.id+":"+temp6.name);
    }
    
    public static void main(String[] args){
        ListTest lt=new ListTest();
        lt.testAdd();
    }
}

5、学生选课-课程查询

    /**
     * 取得List的元素的方法
     * @param args
     */
    public void testGet(){
        int size=coursesToSelect.size();
        System.out.println("有如下课程待选:");
        for(int i=0;i<size;i++){
            Course cr=(Course) coursesToSelect.get(i);
            System.out.println("课程:"+cr.id+":"+cr.name);
        }
    }
    
    /**
     * 通过迭代器来遍历List,不具备存储功能
     * @param args
     */
    public void testIterator(){
        //通过集合的iterator方法,取得迭代器的实例
        Iterator it=coursesToSelect.iterator();
        System.out.println("有如下课程待选(通过迭代器访问):");
        while(it.hasNext()){
            Course cr=(Course)it.next();
            System.out.println("课程:"+cr.id+":"+cr.name);
        }
    }
    
    /**
     * 通过for each方法访问集合元素
     * @param args
     */
    public void testForEach(){
        System.out.println("有如下课程待选(通过for each访问):");
        for(Object obj:coursesToSelect){
            Course cr=(Course)obj;
            System.out.println("课程:"+cr.id+":"+cr.name);
        }
    }
    
    private Iterator coursesToSelect() {
        // TODO Auto-generated method stub
        return null;
    }
    public static void main(String[] args){
        ListTest lt=new ListTest();
        lt.testAdd();
        lt.testGet();
        lt.testIterator();
        lt.testForEach();
    }
}

6、学生选课-课程修改

/**
     * 修改List中的元素
     */
    public void testModify(){
        coursesToSelect.set(4,new Course("7","毛概"));
    }

7、学生选课-课程删除

public void testRemove(){
        //删除方法1
//      Course cr=(Course)coursesToSelect.get(4);
//      System.out.println("我是课程:"+cr.id+":"+cr.name+"我即将被删除");
//      coursesToSelect.remove(cr);
        
        //删除方法2
//      System.out.println("即将被删除4位置的课程");
//      coursesToSelect.remove(4);
        
        //删除方法3
        System.out.println("即将被删除4和5位置的课程");
        Course[] courses={(Course)coursesToSelect.get(4),(Course)coursesToSelect.get(5)};
        coursesToSelect.removeAll(Arrays.asList(courses));
        System.out.println("成功删除课程!");
        testForEach();
    }

8、学生选课-应用泛型管理课程

  • 集合中的元素,可以是任意类型的对象(对象引用)
    如果把某个对象放入集合,则会忽略他的类型,而把他当做object处理
  • 泛型则是规定了某个集合只可以存放特定类型的对象
    会在编译期间进行类型检查
package student;

import java.util.ArrayList;
import java.util.List;

public class TestGeneric {
    /**
     * 带有泛型——Course,的List类型属性,尖括号中是规定的存放类型
     */
    public List<Course> courses;
    
    public TestGeneric() {
        this.courses = new ArrayList<Course>();//初始化带有泛型的courses属性
    }
    
    /**
     * 测试添加
     */
    public void testAdd() {
        Course cr1 = new Course("1","大学语文");
        courses.add(cr1);
        //泛型集合中,不能添加泛型规定的类型及其子类型以外的对象,否则会报错!
//      courses.add("能否添加一些奇怪的东西呢??");
        Course cr2 = new Course("2","Java基础");
        courses.add(cr2);
    }
    
    /**
     * 测试循环遍历
     * 不是作为object类型取出而是规定的course类型
     */
    public void testForEach() {
        for (Course cr : courses) {
            System.out.println(cr.id + ":" + cr.name);
        }
    }
    
    /**
     * 泛型集合可以存入泛型类型、泛型的子类型
     * 泛型结合可以添加泛型的子类型的对象实例
     */
    public void testChild() {
        ChildCourse ccr = new ChildCourse();
        ccr.id = "3";
        ccr.name = "我是子类型的课程对象实例~~";
        courses.add(ccr);
    }
    
    /**
     * 泛型不能使用基本类型
     */
    public void testBasicType() {
        List<Integer> list = new ArrayList<Integer>();
        list.add(1);
        System.out.println("基本类型必须使用包装类作为泛型!" + list.get(0));
    }
    /*
     * 泛型集合中的限定类型不能使用基本类型,必须是引用类型
     * 可以通过使用包装类(Interger、Long...)限定允许存入的基本类型
     */
    
    public static void main(String[] args) {
        TestGeneric tg = new TestGeneric();
        tg.testAdd();
        tg.testForEach();
        tg.testChild();
        tg.testForEach();
        tg.testBasicType();
    }
}

泛型集合中可以存入泛型类型、泛型的子类型
1、泛型集合中的限定类型,不能使用基本数据类型,只能是引用类型。
2、可以通过使用包装类限定允许存入的基本数据类型

9、学生选课-通过Set集合管理课程

  • Set接口
    1、Set是元素无需并且不可以重复的集合,被称为集
    2、HashSet---哈希集,是Set的一个重要实现类
  • 功能说明:
    1、提供备选课程
    2、创建学生兑现,并给该学生添加三门课程(添加在学生的courses--Set类型的属性中)
    显示备选课程
    循环三次,每次输入课程ID
    往学生的courses属性中添加与输入的ID匹配的课程
    输出学生选择的课程
package student;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Scanner;

import com.imooc.Course;
import com.imooc.Student;

/*
 * Set接口及其实现类HashSet
 * Set是元素无序并且不可以重复的集合,被称为集 
 * HashSet--哈希集,是Set的一个重要实现类
 */
/*
 * 案例功能说明
 * 提供备选课程
 * 创建学生对象,并给该学生添加三门课程(添加在学生的courses--Set类型的属性中)
 * --显示备选课程、循环三次,每次输入课程ID、
 * --往学生的courses属性中添加与输入的ID匹配的课程、输出学生选择的课程
 */
public class SetTest {
    
    public List<Course> coursesToSelect;
    private Scanner console;
    public Student student; 
    public SetTest() {
        coursesToSelect = new ArrayList<Course>();
        console = new Scanner(System.in);
    }
    
    /**
     * 用于往coursesToSelect中添加备选课程
     */
    public void testAdd() {
        //创建一个课程对象,并通过调用add方法,添加到备选课程List中
        Course cr1 = new Course("1" , "数据结构");
        coursesToSelect.add(cr1);
        Course temp = (Course) coursesToSelect.get(0);
//      System.out.println("添加了课程:" + temp.id + ":" + temp.name); 
        
        Course cr2 = new Course("2", "C语言");
        coursesToSelect.add(0, cr2);
        Course temp2 = (Course) coursesToSelect.get(0);
//      System.out.println("添加了课程:" + temp2.id + ":" + temp2.name);
        
//      coursesToSelect.add(cr1);
//      Course temp0 = (Course) coursesToSelect.get(2);
//      System.out.println("添加了课程:" + temp.id + ":" + temp.name); 
        
        
        //以下方法会抛出数组下标越界异常
//      Course cr3 = new Course("3", "test");
//      coursesToSelect.add(4, cr3);
        
        Course[] course = {new Course("3", "离散数学"), new Course("4", "汇编语言")};
        coursesToSelect.addAll(Arrays.asList(course));
        Course temp3 = (Course) coursesToSelect.get(2);
        Course temp4 = (Course) coursesToSelect.get(3);
        
//      System.out.println("添加了两门课程:" + temp3.id + ":" + 
//              temp3.name + ";" + temp4.id + ":" + temp4.name);
        
        Course[] course2 = {new Course("5", "高等数学"), new Course("6", "大学英语")};
        coursesToSelect.addAll(2, Arrays.asList(course2));
        Course temp5 = (Course) coursesToSelect.get(2);
        Course temp6 = (Course) coursesToSelect.get(3);
//      System.out.println("添加了两门课程:" + temp5.id + ":" + 
//              temp5.name + ";" + temp6.id + ":" + temp6.name);
        
    }
    
    /**
     * 通过for each方法访问集合元素
     * @param args
     */
    public void testForEach() {
        System.out.println("有如下课程待选(通过for each访问):");
        for (Object obj : coursesToSelect) {
            Course cr = (Course) obj;
            System.out.println("课程:" + cr.id + ":" + cr.name);
        }
    }
    
    public static void main(String[] args) {
        SetTest st = new SetTest();
        st.testAdd();
        st.testForEach();
        //创建一个学生对象
        Student student=new Student("1","小明");
        System.out.println("欢迎学生:"+student.name +"选课!");
        //创建一个Scanner对象,用来接收从键盘输入的课程ID
        Scanner console=new Scanner(System.in);
        
        for (int i = 0; i < 3; i++) {
            System.out.println("请输入课程ID");
            String courseId=console.next();
            for (Course cr:st.coursesToSelect) { //比对Course中coursesToSelect的每个元素
            if(cr.id.equals(courseId)) {
                student.courses.add(cr);
                    /**
                     * Set中,添加某个对象,无论添加多少次,
                     * 最终只会保留一个该对象(的引用),
                     * 并且,保留的是第一次添加的那一个
                     */
//                  student.courses.add(null);
//                  student.courses.add(cr);
                }
            }   
        }
        st.testForEachForSet(student);
    }
    public void testForEachForSet(Student student) {
        //打印输出,学生所选的课程!
        System.out.println("共选择了:" + student.courses.size() + "门课程!");
        for (Course cr : student.courses) {
            System.out.println("选择了课程:" + cr.id + ":" + cr.name);
        }
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,390评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,821评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,632评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,170评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,033评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,098评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,511评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,204评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,479评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,572评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,341评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,893评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,171评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,486评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,676评论 2 335

推荐阅读更多精彩内容

  • 1、学生选课-判断List中课程是否存在 思考:1、在课程序列中,如何判断是否包含某门课或者某几门课程?2、如果课...
    夏沫xx阅读 428评论 0 2
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,497评论 18 399
  • title: java集合框架学习总结 tags:集合框架 categories:总结 date: 2017-03...
    行径行阅读 1,665评论 0 2
  • 概述 Java集合框架由Java类库的一系列接口、抽象类以及具体实现类组成。我们这里所说的集合就是把一组对象组织到...
    absfree阅读 1,232评论 0 10
  • 我的一星期开始了我先座了晨诵配音我吃完饭就哣我妹 我去学了游泳 学完了游泳学了书法 我回家看了书 一天又开始了我干...
    冰糖小妹葫芦大哥阅读 275评论 0 0