您的位置:首页 > 编程语言 > Java开发

Java集合框架(上)

2016-06-29 10:30 423 查看
Java中集合类的概念:

是一种工具类,就像是容器,储存任意数量的具有共同属性的对象。

集合的作用:

在类的内部,对数据进行组织。

简单而快速地搜索大数量的条目。

有的集合接口,提供了一系列排列有序的元素,并且可以在序列中间快速快速的插入或删除有关元素。

有的集合接口,提供了映射的关系,可以通过关键字(key)快速查找到对应的唯一对象,而这个关键字可以是任意类型。

为什么选择集合,而不是数组?

数组的长度是固定的,而集合的长度是可变的

数组只能通过数组下标去访问,且下标数据类型固定,只能是整型,很多情况下我们不知道数组元素的具体位置,因此只能一个个遍历去查找,这种情况当数组很庞大的时候程序非常耗时。而有的集合可以通过任意类型的关键字查找所映射的具体对象。

Java集合框架体系结构



对于Collection,最上层是父接口,二层是父接口下的子接口,三层是子接口对应的实现类。

对于Map,其最常用的实现类的HashMap;Map中有内部类Entry,翻译成键值对;一个Key(任意类型)对应一个Value(任意类型)正是Entry类的一个实例。

List集合中的元素是有序并且可以重复的。

Set集合中的元素是无序的,不可重复的。

实例演练:

学生选课功能实现:

选择课程(往集合中添加元素)

删除所选的某门课程(删除集合中的元素)

查看所选课程

修改所选课程

课程类(Course.java):

package com.imooc.collection;

public class Course {

public String id;
public String name;

public Course(String id, String name) {
super();
this.id = id;
this.name = name;
}
}


学生类(Student.java):

package com.imooc.collection;

import java.util.HashSet;
import java.util.Set;

public class Student {

public String id;
public String name;

public Set<Course> courses;

public Student(String id, String name) {
super();
this.id = id;
this.name = name;
this.courses = new HashSet<Course>();
}
}


ArrayList增删改查(ListTest.java):

package com.imooc.collection;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
public class ListTest {

/*List中的元素是有序并且可以重复的*/
public List CoursesToSelect;

public ListTest(){
//注意List是个接口,不能直接将其实例化
this.CoursesToSelect = new ArrayList();
}

public void TestAdd(){

/*---普通add测试---*/
Course cr1 = new Course("1","数据结构");
CoursesToSelect.add(cr1);

/*---指定位置add测试,下挤---*/
Course cr2 = new Course("2","常用算法");
CoursesToSelect.add(0, cr2);//添加到第一个位置,会将原有的挤下去。

/*---越界add测试---*/
//Course cr3 = new Course("3","JAVA");
//CoursesToSelect.add(3, cr3);
/*
* 注意!!
* 0,1,2均不报错
* 3报错:java.lang.IndexOutOfBoundsException  下标越界
* */

/*---普通组合add添加---*/
Course[] courseList = {new Course("3","Javaweb"),new Course("4","数据库")};
CoursesToSelect.addAll(Arrays.asList(courseList));

/*---指定位置组合add添加---*/
Course[] courseList2 = {new Course("5","高等数学"),new Course("6","计算机网络")};
CoursesToSelect.addAll(2,Arrays.asList(courseList2));
}

public void testQueryAll(){  //查看全部元素
System.out.println("普通遍历List");
for(int i=0;i<CoursesToSelect.size();i++){
/*对象存入集合都变成Object类型,取出时需要类型转换*/
Course tempCourse = (Course) CoursesToSelect.get(i);
System.out.println("课程"+(i+1)+":"+tempCourse.name+" 课程id:"+tempCourse.id);
}
}

public void testIterator(){  //通过迭代器遍历List

System.out.println("通过迭代器遍历List");
//迭代器是用来遍历集合中的元素的,本身不具备任何存储元素的功能;依赖于某个集合存在,本身不能独立存在
//迭代器本身是个接口,通过集合的iterator()方法,取得迭代器的实例
Iterator it = CoursesToSelect.iterator();
while(it.hasNext()){
Course cr = (Course) it.next();
System.out.println("课程:"+cr.name+" 课程id:"+cr.id);
}
}

public void testForEach(){  //通过foreach遍历List

System.out.println("通过foreach遍历List");
for(Object obj:CoursesToSelect){
Course cr = (Course)obj;
System.out.println("课程:"+cr.name+" 课程id:"+cr.id);
}
}

public void testModify(){  //修改
CoursesToSelect.set(0, new Course("100","Spring"));
}

public void testRemove(){  //删除,记住每删除一次,元素都会上移

CoursesToSelect.remove(1);//删除的第一种方式

/*在上面删除位置1的元素后,后面的元素会整体上移,位置1又有了新元素,所以下面的语句是删除现在位置2的新元素*/
Course cr = (Course) CoursesToSelect.get(2);   //删除的第二种方式
CoursesToSelect.remove(cr);

Course[] courseList =
{(Course) CoursesToSelect.get(1),
(Course) CoursesToSelect.get(2),
(Course) CoursesToSelect.get(3)};
CoursesToSelect.removeAll(Arrays.asList(courseList));   //删除的第三种方式,removeAll

}

public static void main(String[] args){

ListTest lt = new ListTest();
lt.TestAdd();
lt.testQueryAll();
lt.testIterator();
lt.testModify();  //修改课程
lt.testRemove();  //删除课程
lt.testForEach();
}
}


运行结果:

普通遍历List

课程1:常用算法 课程id:2

课程2:数据结构 课程id:1

课程3:高等数学 课程id:5

课程4:计算机网络 课程id:6

课程5:Javaweb 课程id:3

课程6:数据库 课程id:4

通过迭代器遍历List

课程:常用算法 课程id:2

课程:数据结构 课程id:1

课程:高等数学 课程id:5

课程:计算机网络 课程id:6

课程:Javaweb 课程id:3

课程:数据库 课程id:4

通过foreach遍历List

课程:Spring 课程id:100

ArrayList泛型管理集合元素(TestGeneric.java):

package com.imooc.collection;

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

public class TestGeneric {
//规定当前List只能存放Course类型的元素,否则编译器会报错
//若无泛型,添加了其他奇怪的元素编译器不会报错,但是运行时就会报错
public List<Course> courses;
public TestGeneric(){
this.courses = new ArrayList<Course>();
}

public void testAdd(){
Course cr1 = new Course("1","数据结构");
courses.add(cr1);
}

public void testForEach(){
for(Course course:courses){  //不需要再强制类型转换,直接取元素出来使用
System.out.println("课程:"+course.name);
}
}
public static void main(String[] args){
TestGeneric tg = new TestGeneric();
tg.testAdd();
tg.testForEach();
}

//指定泛型的List还可以存放指定泛型元素实例的子类元素实例
//泛型不能是基本类型数据,例如int,char等
//泛型必须是引用类型的数据,可以使用包装类对基本数据类型进行装箱然后再使用泛型
}


运行结果:

课程:数据结构

Set集合的基本用法(SetTest.java):

package com.imooc.collection;

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

public class SetTest {

public List<Course> CoursesToSelect;
public SetTest(){
this.CoursesToSelect = new ArrayList<Course>();
}

public void TestAdd(){

Course cr1 = new Course("1","数据结构");
CoursesToSelect.add(cr1);

Course cr2 = new Course("2","常用算法");
CoursesToSelect.add(0, cr2);

Course[] courseList = {new Course("3","Javaweb"),new Course("4","数据库")};
CoursesToSelect.addAll(Arrays.asList(courseList));

Course[] courseList2 = {new Course("5","高等数学"),new Course("6","计算机网络")};
CoursesToSelect.addAll(2,Arrays.asList(courseList2));
}

public void testForEach(){
for(Course course:CoursesToSelect){
System.out.println("课程:"+course.name+" 课程id:"+course.id);
}
}

public static void main(String[] args){
SetTest st = new SetTest();
st.TestAdd();
st.testForEach();

//创建一个学生对象
Student stu1= new Student("1","小明");
System.out.println("欢迎"+stu1.name+"选课!");

Scanner sc = new Scanner(System.in);
for(int i=0;i<3;i++){

System.out.println("请输入课程ID");
String courseId = sc.next();

for(Course course:st.CoursesToSelect){
if(course.id.equals(courseId)){  //字符串是对象,其equals()方法比较的是实际内容!
stu1.courses.add(course);
}
}
}

st.testForEachForSet(stu1);
}

public void testForEachForSet(Student stu){

//打印输出学生所选的课程
//遍历Set中的元素只能用foreach或是iterator,不能想List那样用get(index),因为Set是无序的。
//Set中的元素是不可重复的,重复的添加Set只会保存一个该对象(的引用)
//Set是可以添加空对象的,null
//Set没有提供像List那样的set()方法,因为Set集合是无序的
System.out.println("共选择了"+stu.courses.size()+"门课程");
for(Course course:stu.courses){
System.out.println(stu.name+"选择了"+course.name+" 课程id:"+course.id);
}
//没有介绍的关于Set的remove(),size()等方法,大致跟List一样
}
}


运行结果:

课程:常用算法 课程id:2

课程:数据结构 课程id:1

课程:高等数学 课程id:5

课程:计算机网络 课程id:6

课程:Javaweb 课程id:3

课程:数据库 课程id:4

欢迎小明选课!

请输入课程ID

4

请输入课程ID

4

请输入课程ID

6

共选择了2门课程

小明选择了计算机网络 课程id:6

小明选择了数据库 课程id:4
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息