--------- 、、期待与您交流!----------
一、为什么会出现集合类
面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象的操作,就对对象进行存储,集合就是存储对象最常用的一种方式。
二、数组和集合类同是容器,有何不同?
数组虽然也可以存储对象,但长度是固定的,集合长度是可变的,数组中可以存储基本数据类型,集合只能存储引用类型,即对象。
三、集合的特点:
集合只用于存储对象,集合长度是可变的,集合可以存储不同类型的对象。
四、集合中有很多的子类,为什么会出现这么多的容器呢?
因为每一个容器对数据的存储方式都不同,这个存储方式称之为数据结构。
五、注意:
1.add方法的参数类型是Object,以便于接收任意类型的对象。
2.集合中存储的都是对象的引用。
六、什么是迭代器?
其实就是取出集合元素的工具,迭代就是取出元素的方式。
七、以下两种迭代的方式的区别?
//...(其它过程略)Iterator it = al.iterator();while(it.hasNext()){ System.out.println(it.next());}//...(其它过程略)for(Iterator it = al.iterator(); it.hasNext(); ){ System.out.println(it.next());}//...(其它过程略)
如果用while循环,因为it指向了一个对象,那么循环结束以后,it还会存在于内存当中,直到程序结束,而用for循环,因为it是局部变量,那么当循环结束以后,it就被释放掉了。
八、迭代需要注意的地方。
在迭代时,不可以通过集合对象的方法操作集合中的元素,否则会发生(并发修改异常)ConcurrenModificationException。所以,在迭代时,只能用迭代的方法操作元素,可是Iterator方法是有限的只能对元素进行判断(hasNext),取出(next),删除(remove)等操作。如果想要其他的操作如添加,修改等,就需要使用其子接口,ListIterator。该接口只能通过List集合的ListIterator方法获取。
九、Comparable接口和Comparator接口
1、Comparable接口是java.lang包当中的接口。
Comparable接口适用于一个类有自然顺序的时候,假定对象集合是同一类型,该接口允许把集合排序成自然顺序。当中有个有方法:int comparaTo(T o):比较当前实例对象与对象o,如果位于对象o之前,返回负值,如果两个对象在排序中位置相同,则返回0,如果位于对象o后面,则返回正值。以下是的一些数据类型的自然排序,虽然一些类共享了同一种自然排序,但只有相互可比的类才能排序。
按数字大小排序:BigDecimal,BigInteger,Byte,Double,Float,Integer,Long,Short。
按Unicode值的数字大小排序:Character。
按字符串中字符Unicode值排序:String。
在自定的类实现Comparable接口来创建自己的排序顺序时,要复写compareTo()方法,同时也应该复写equals()和hashCode()以确保两个相等的对象返回同一个哈希码。
如HashSet是如何保证元素唯一性的呢?
是通过元素的两个方法,hashCode和equals来完成,如果元素的hashCode值相同,才会判断equals是否为true(如果为true了,元素相同,那么就不存储,前提是要轮到它判断),如果元素的hashCode值不相同,则不会调用equals。要注意的是,对于判断元素是否存在,以及删除等操作,依赖的方法都是hashCode和equals方法。
2、Comparator是java.util包中的接口。
若一个类不能用于实现Comparable,或者不是我们所需要的缺省的Comparable行为并想提供自己的排序顺序(可能有多种排序方式),那么这时,我们就可以实现Comparator接口。那么要覆盖以下两个方法:
(1)int compare(T o1, T o2):比较用来排序的两个参数。根据第一个参数小于(位于第二个参数的前面)、等于(处于第二个参数的相同位置)或大于(位于第二个参数的后面)第二个参数分别返回负整数、零或正整数。实际上:与Comparable相似,0返回值不表示元素相等。一个0返回值只是表示两个对象排在同一位置。由Comparator用户决定如何处理。如果两个不相等的元素比较的结果为零,您首先应该确信那就是您要的结果,然后记录行为。
(2)boolean equals(Object obj):指示对象obj是否和比较器相等。该方法覆写Object的equals()方法,检查的是Comparator实现的等同性,不是处于比较状态下的对象。
十、集合体系如下(只列出了常用的集合)
十一、最后举一个例子来说明(涉及到了IO)
注意:当两种方式都存在时,会使用自定的比较方式。
/*有五个学生,每个学生有3门课的成绩,从键盘输入以上数据(包括姓名,三门课成绩),输入的格式:如:zhagnsan,30,40,60计算出总成绩,并把学生的信息和计算出的总分数高低顺序存放在磁盘文件"stud.txt"中。1,描述学生对象。2,定义一个可操作学生对象的工具类。思想:1,通过获取键盘录入一行数据,并将该行中的信息取出封装成学生对象。2,因为学生有很多,那么就需要存储,使用到集合。因为要对学生的总分排序。 所以可以使用TreeSet。3,将集合的信息写入到一个文件中。*/import java.io.*;import java.util.*;class Student implements Comparable{ //定义学生属性 private String name; private int ma,cn,en; private int sum; //定义无参构造方法 Student(){} //定义有参构造方法 Student(String name,int ma,int cn,int en) { this.name = name; this.ma = ma; this.cn = cn; this.en = en; sum = ma + cn + en; } //覆盖Comarable的compareTo方法。 public int compareTo(Student s) { //先按总分排序 int num = new Integer(this.sum).compareTo(new Integer(s.sum)); //如果总分相同,再按姓名(字符串中字符的Unicode)排序。 if(num==0) return this.name.compareTo(s.name); return num; } //获取姓名 public String getName() { return name; } //获取总分 public int getSum() { return sum; } //覆盖hashCode方法 public int hashCode() { return name.hashCode()+sum*78; } //覆盖equals方法 public boolean equals(Object obj) { if(!(obj instanceof Student)) throw new ClassCastException("类型不匹配"); Student s = (Student)obj; return this.name.equals(s.name) && this.sum==s.sum; } public String toString() { return "student["+name+", "+ma+", "+cn+", "+en+"]"; }}//定义一个操作学生信息的工具类class StudentInfoTool{ //定义一个空参数的方法,将不使用比较器 public static Set getStudents()throws IOException { return getStudents(null); } //定义一个将比较器作为参数的方法,以使用自定义的比较器 public static Set getStudents(Comparator cmp)throws IOException { BufferedReader bufr = new BufferedReader(new InputStreamReader(System.in)); String line = null; Set stus = null; //如果没有传入比较器 if(cmp==null) stus = new TreeSet (); else stus = new TreeSet (cmp); while((line=bufr.readLine())!=null) { if("over".equals(line)) break; String[] info = line.split(","); Student stu = new Student(info[0],Integer.parseInt(info[1]), Integer.parseInt(info[2]), Integer.parseInt(info[3])); stus.add(stu); } bufr.close(); return stus; } public static void writeFile(Set stus)throws IOException { //定义一个写入流对象, BufferedWriter bufw = new BufferedWriter(new FileWriter("stuinfo.txt")); //不止一个学生对象,所以遍历每个学生对象,并将学生信息写入到文件中 for(Student stu : stus) { bufw.write(stu.toString()+"\t"); bufw.write(stu.getSum()+""); //换行 bufw.newLine(); //刷新 bufw.flush(); } //关闭写入流对象 bufw.close(); }}//测试类class StudentInfoTest{ public static void main(String[] args) throws IOException { //强制把比较器反转,以便把学生的分数从高到低打印 Comparator cmp = Collections.reverseOrder(); //将反转后的比较器传入Set集合 Set stus = StudentInfoTool.getStudents(cmp); //把学生信息写入到指定文件中 StudentInfoTool.writeFile(stus); }}
--------- 、、期待与您交流!----------