黑马程序员技术交流社区
标题:
这段程序没看懂,请大家帮忙看下
[打印本页]
作者:
qmlovewhr
时间:
2013-7-5 14:45
标题:
这段程序没看懂,请大家帮忙看下
本帖最后由 赵海洋 于 2013-7-6 18:16 编辑
import java.util.*;
class TreeSetDemo
{
public static void main(String[] args)
{
TreeSet ts=new TreeSet();
ts.add(new Student("lisi01",22));
ts.add(new Student("lisi02",20));
ts.add(new Student("lisi04",19));
ts.add(new Student("lisi03",19));
Iterator it=ts.iterator();
while(it.hasNext())
{
Student stu=(Student)it.next();
System.out.println(stu.getName()+"..."+stu.getAge());
}
}
}
class Student implements Comparable//该接口强制让学生具备比较性
{
private String name;
private int age;
Student(String name,int age)
{
this.name=name;
this.age=age;
}
public int compareTo(Object obj)
{
if(!(obj instanceof Student))
throw new RuntimeException("不是学生对象");
Student s=(Student)obj;
System.out.println(this.name+"......compareTo......"+s.name);
if(this.age>s.age)
return 1;
if(this.age==s.age)
{
return this.name.compareTo(s.name);
}
return -1;
}
public String getName()
{
return this.name;
}
public int getAge()
{
return this.age;
}
}
这段程序中的compateTo方法没太看明白,你们说TreeSet是自动调用compartTo方法的哈,this.name应该指调用TreeSet添加对象一进来的名字,可是s.name指的是在这之前添加的对象的名字,也没有循环结构,也没有多次调用,它怎么就能逐个去进行比较?Student stu=(Student)it.next();另外这是一个强制类型转制吧,它把it.next()取出来的对象强制转成Student类的对象吧,这样理解没错吧?求大家给个更容易理解的方式。
作者:
哪颗最亮的星星
时间:
2013-7-5 15:11
首先:基于 TreeMap 的 NavigableSet 实现。使用元素的自然顺序对元素进行排序,或者根据创建 set 时提供的 Comparator 进行排序,具体取决于使用的构造方法。
学生类实现了Comparable接口,这样它就具备了可比较性,当把对象添加到集合的时候,集合会调用你定你的CompareTo方法。当学生类不具备可比较性的时候,集合会按照自然排序对元素进行排序。
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2