第十四章 JAVA中的集合框架(上)List

来源:互联网 发布:电动汽车环保贡献数据 编辑:程序博客网 时间:2024/05/22 10:26

第一节 JAVA中的集合框架概述

集合的概念,现实生活中:很多事物凑在一起就是一个集合;数学中的集合:具有相同属性事物的总体;JAVA中的集合:是一种工具类,就像是容器,储存任意数量的具有共同属性的对象。集合的作用:在类的内部,对数据进行组织(如果有些属性类型相同,但意义与作用不同,咱们就不能把它们放到集合,如学生的姓名和性别属性),简单而快速的搜索大数量的条目。
有的集合接口,提供了一系列排列有序的元素,并且可以在序列中间快速的插入或者删除有关元素;
有的集合接口,提供了映射关系,可以通过关键字key去快速查找到对应的唯一对象,而这个关键字可以是任意类型。
集合其实就是用来承装其它对象的容器。
与数组相比,为何选择集合而不是数组?数组的长度固定,还得复制,集合的长度可变。数组只能通过数组下标访问元素,类型固定,而有的集合可以通过任意类型查找所映射的具体对象,数组还要遍历元素比较麻烦。
集合的框架体系结构:

将collection想象成单身宿舍,三个子接口。
1.List(序列):排列有序,可重复
2.Queue(队列):排列有序,可重复
3.set(集):无序,不可重复
将map当成成对出现,Collection 是存储的一个一个的对象,而Map提供映射的关系,内部以的Key,Value两个对象为一个映射来存储数据,Entry类(键值对)是Map的内部类,Key,Value就是Entry的实例,key和value可以是任意类型的对象。两个根接口:Collection和Map,Collection的子接口有:List序列(有序可重复)、Queue队列、Set集(无序不可重复)。实现类分别:ArrayList数组序列,LinkedList链表也是List的接口实现类,HashSet哈希集;Map的实现类有:HashMap哈希表。
在Collection或Map内部是如何存储对象呢?在每一个Collection类中,存储的就是一个个独立的对象,而Map内部有些特殊。有些集合内部能提供一种映射的关系,就是指Map类,在Map类的内部,一个key一个value两个对象为一个映射去存储数据,这样的一个映射就是Entry类的实例,这个Entry类是Map类的一个内部类,咱们把它翻译成键值对,一个键一个值,两个凑成映射的一对,其中key和value可以是任意类型的对象。
在Collection和Map众多子接口和实现类当中,ArrayList、HashSet、HashMap使用最多的三个实现类

第二节 Collection接口List接口简介

Collection接口、子接口及其实现类,Collection接口是java框架中的根接口,也是List、Set和Queue接口的父接口;定义了很多方法,可用于操作List、Set和Queue的方法,对集合的增删改查,可在API中查看Collection的介绍和方法。
List接口和其实现类 ArrayList
1.List是元素有序并且可以重复的集合,被称为序列
2.List可以精确的控制每个元素的插入位置,或删除某个指定位置的元素
3.ArrayList 数组序列,是List的一个重要实现类
4.ArrayList底层是由数组实现的

第三节 学生选课–创建学生类和课程类

/** * 课程类 * Created by Administrator on 2017/4/2. */public class Course {    private String id;    private String name;    public String getId() {        return id;    }    public String getName(){        return name;    }    public void setId(String id){        this.id=id;    }    public void setName(String name) {        this.name = name;    }    public Course(String id,String name){        this.id=id;        this.name=name;    }}import java.util.HashSet;import java.util.Set;/** * 学生类 * Created by Administrator on 2017/4/2. */public class Student {    private String id;    private String name;    public Set courses;    //课程信息存放在set属性里,和list一样是一个子接口    public String getId() {        return id;    }    public void setId(String id) {        this.id = id;    }    public String getName() {        return name;    }    public void setName(String name) {        this.name = name;    }    public Student(String id,String name){        this.id=id;        this.name=name;        this.courses=new HashSet();        //构造方法里不能直接实例化,因为set是一个接口,通过HashSet()对courses实例化,HashSet是一个重要的实现类    }}

第四节 学生选课–添加课程I

在这里注意在List中添加元素,如果插入位置如果大于容量的长度就会报越界异常,如等于容量会在队尾添加一个,小于0也会报错。

import java.util.ArrayList;import java.util.List;/** * 添加课程 * Created by Administrator on 2017/4/2. *///既然学生要选课就要存放备选课程,用一个List容器来存放备选课程public class ListTest {    //新建ListTest类    //创建一个List类型的属性,用于存放备选课程的容器List    public List courseToSelect;  //给类添加一个构造方法    public ListTest(){        this.courseToSelect=new ArrayList();        //因为List是一个接口,咱们不能直接将它实例化,这里就引入了ArrayList来实现接口的实例化    }    //用于往courseToSelect添加课程对象    public void testAdd(){        //首先要有一个课程对象的实例        Course cr1=new Course("1","数据结构");        //调用add方法添加        courseToSelect.add(cr1);        //打印输出 courseToSelect.get(0)的数据        //当一个对象存入集合后它就变成了Object类型的数据取出时就要把类型转换回来        Course temp=(Course) courseToSelect.get(0);        System.out.println("成功添加课程:"+temp.getId()+":"+temp.getName());        Course cr2=new Course("2","C语言");        //重载的add方法可以指定位置添加元素        courseToSelect.add(0,cr2);        Course temp2=(Course) courseToSelect.get(0);        System.out.println("成功添加课程:"+temp2.getId()+":"+temp2.getName());    }    //调用main方法测试    public static void main(String[] args) {        ListTest lt=new ListTest();        lt.testAdd();    }}

第五节 添加课程II

add和addAll分别各有两个方法,参数不同。其中addAll 需要先把数组转换成list Arrays.asList();这个方法也是有两种用法,可以指定位置添加元素。

Course[] cr3={new Course("3","离散数学"),new Course("4","汇编语言")};        //创建一个课程数组        //调用addAll把数组添加进去,但是这儿的参数要是Collection的实例,        // 就需要把数组转换成List,用Arrays.asList()方法        courseToSelect.addAll(Arrays.asList(cr3));        //输出        Course temp3=(Course)courseToSelect.get(2);        Course temp4=(Course)courseToSelect.get(3);        System.out.println("成功添加课程:"+temp3.getId()+":"+temp3.getName()+";"                +temp4.getId()+":"+temp4.getName());        Course[] cr4={new Course("5","高等数学"),new Course("6","大学英语")};        courseToSelect.addAll(2,Arrays.asList(cr4));        Course temp5=(Course)courseToSelect.get(2);        Course temp6=(Course)courseToSelect.get(3);        System.out.println("成功添加课程:"+temp5.getId()+":"+temp5.getName()+";"                +temp6.getId()+":"+temp6.getName());    }

第六节 学生选课–课程查询

get方法可以取到指定位置的元素,如果想取出每一个则可以使用for循环来遍历List,由于List中的数据类型是Object,再输出时需要强制转换下类型。长度集合.size()方法。

 /**     * 定义方法循环遍历List中的元素     */    public void test1(){        System.out.println("使用for循环遍历List中一共有以下课程");        for(int i=0;i<courseToSelect.size();i++){            //因为类型不同需要强制类型转换            System.out.println("课程:"+((Course)courseToSelect.get(i)).getId()+":"+                    ((Course)courseToSelect.get(i)).getName());        }    }    public void test2(){        System.out.println("使用foreach循环遍历List中一共有以下课程");        for(Object obj:courseToSelect){            //因为类型不同需要强制类型转换            System.out.println("课程:"+((Course)obj).getId() +":"+((Course)obj).getName());        }    }

接下来还可以试验下List的重复性问题,List中可以重复元素
还有一种的特殊遍历方法,是通过迭代器来遍历集合中的元素 Iterator
Iterator就是迭代器的意思,在Collection接口中定义了iterator方法,通过这个方法可以返回一个当前集合对象的迭代器,再通过这个迭代器去遍历集合中的每个元素,Iterator本身也是一个接口。迭代器本身只是用来遍历元素的,它自己不具备任何存储的功能,可以理解为迭代器依赖于某个集合而存在,本身不能独立存在。
Iterator it=courseToSelect.iterator();就是循环的那个List,可以提前设定类型,这样就不用再强制转换了。然后it.hasNext();
表示是否还有下一个Course对象,返回true就进入 it.next表示获得当前这个Course(强转)对象

 public void test3(){        System.out.println("通过迭代器遍历集合中元素,共有以下课程:");        //通过集合的iterator方法来创建迭代器的实例        Iterator<Course> it=courseToSelect.iterator();        //遍历元素如有元素则输出它的真值        while(it.hasNext()){            Course cr=it.next();            System.out.println("课程:"+cr.getId()+":"+cr.getName());        }    }

第七节 学生选课–课程修改

如何修改List张的元素?用set方法,用指定元素替换列表中指定位置的元素。
set(int index,E element)
参数,要替换元素的索引,要在指定位置存储的元素
courseToSelect.set(4, new Course(“7”,”毛概”));

第八节 学生选课–课程删除

删除List中的元素,删除的方法有remove 和removeAll方法
remove(int index)移除列表中指定位置的元素
remove(object o)此列表中移除第一次出现的指定元素(如果存在)
removeAll(Collection

public void test5(){        Course[] courses={(Course)courseToSelect.get(4),(Course)courseToSelect.get(5)};        courseToSelect.removeAll(Arrays.asList(courses));        courseToSelect.remove(0);        courseToSelect.remove(courseToSelect.get(0));    }

第九节 学生选课–应用泛型管理

是否有方法可以控制我往某个List或某个集合中添加元素的类型呢?
这时我们就要用到泛型。
泛型:集合中的元素,可以是任意类型的对象(对象的引用),集合里储存的都是一个个引用,它们都是指向某个具体的对象的。如果把某个对象放入集合,则会忽略他的类型,仅仅把它当做Object来处理,取出也是把它当做Object来取出。泛型则是规定了某个集合只能存放特定类型的对象,并且会在编译期间对其进行类型检查,可以直接按指定类型获取出集合中的元素,这样我们在后续获取并使用时不用因为Object类型再去强制转换了,直接就能使用。

public class ListText {    public List<Course> courses;    public ListText(){        this.courses=new ArrayList<Course>();    }}

第十节 应用泛型管理课程

其实在泛型集合中,除了可以保存泛型类型的对象实例,还可以存入泛型的子类型的对象实例。泛型集合可以添加泛型子类型的对象实例,泛型不能是基本类型,必须是引用类型,如果非要用基本类型,可以通过使用包装类限定允许存入的基本数据类型。int Integer long Long boolean Boolean泛型是基本类型的包装类的实例化 举例:
List< Integer > list=new ArrayList < Integer > ();

第十一节 通过Set集合来管理课程

Set接口及其实现类——HashSet,Set是元素无序并且不可以重复的集合,被称为集,HashSet——哈希集,是Set的一个重要实现类,Set没有提供方法去修改某个位置上的元素,由于List有序,Set无序且不可重复,所以Set不可能提供一个指定索引位置,去修改相应元素的办法。没有set()方法,一样有add addAll remove removeAll size()等方法,Set方法的遍历只能用foreach或者iterator,不能用get方法,因为无序,也无法查询指定索引位置的元素。

package student;import java.util.Arrays;import java.util.List;import java.util.ArrayList;import java.util.Scanner;/** * Created by Administrator on 2017/4/3. */public class SetTest {    /**     *案例功能:     * 提供备选课程     * 创建学生对象,并给该学生添加三门课程添加在学生的courses—Set     * 类型的属性当中     * 显示备选课程     * 循环三次,每次输入课程ID     * 往学生的courses属性中添加与输入的ID相匹配的课程,     * 输出学生选择的课程     */    //定义一个课程List,并且调用构造方法初始化。后将之前的添加方法赋值过来并遍历课程输出    public List<Course> courseToSelect;    public SetTest(){        this.courseToSelect=new ArrayList<Course>();    }    public void testAdd(){        //首先要有一个课程对象的实例        Course cr1=new Course("1","数据结构");        //调用add方法添加        courseToSelect.add(cr1);        //打印输出 courseToSelect.get(0)的数据        //当一个对象存入集合后它就变成了Object类型的数据取出时就要把类型转换回来        Course temp=(Course) courseToSelect.get(0);        System.out.println("成功添加课程:"+temp.getId()+":"+temp.getName());        Course cr2=new Course("2","C语言");        //重载的add方法可以指定位置添加元素        courseToSelect.add(0,cr2);        Course temp2=(Course) courseToSelect.get(0);        System.out.println("成功添加课程:"+temp2.getId()+":"+temp2.getName());        Course[] cr3={new Course("3","离散数学"),new Course("4","汇编语言")};        //创建一个课程数组        //调用addAll把数组添加进去,但是这儿的参数要是Collection的实例,        // 就需要把数组转换成List,用Arrays.asList()方法        courseToSelect.addAll(Arrays.asList(cr3));        //输出        Course temp3=(Course)courseToSelect.get(2);        Course temp4=(Course)courseToSelect.get(3);        System.out.println("成功添加课程:"+temp3.getId()+":"+temp3.getName()+";"                +temp4.getId()+":"+temp4.getName());        Course[] cr4={new Course("5","高等数学"),new Course("6","大学英语")};        courseToSelect.addAll(2,Arrays.asList(cr4));        Course temp5=(Course)courseToSelect.get(2);        Course temp6=(Course)courseToSelect.get(3);        System.out.println("成功添加课程:"+temp5.getId()+":"+temp5.getName()+";"                +temp6.getId()+":"+temp6.getName());    }    public void test2(){        System.out.println("使用foreach循环遍历List中一共有以下课程:");        for(Object obj:courseToSelect){            //因为类型不同需要强制类型转换            System.out.println("课程:"+((Course)obj).getId() +":"+((Course)obj).getName());        }    }    public static void main(String[] args) {        SetTest st=new SetTest();        st.testAdd();        st.test2();        Student st1=new Student("1","宫园薰");        System.out.println("欢迎"+st1.getName()+"同学选课!每位同学可以选取三门课程哦");        Scanner sc=new Scanner(System.in);        //for循环循环三次,通过对比ID来存入对应的课程信息        for(int i=0;i<3;i++) {            System.out.println("请输入您选择的课程ID:");            String courseId = sc.next();            for (Course cr : st.courseToSelect) {                if (courseId.equals(cr.getId())) {                    st1.courses.add(cr);                    break;                }            }        }        for(Course cr2:st1.courses){            System.out.println("您选择了课程:ID:"+cr2.getId()+":"+cr2.getName());        }    }}
0 0
原创粉丝点击