A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© qmlovewhr 中级黑马   /  2013-7-5 14:45  /  1084 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 赵海洋 于 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:49

评分

参与人数 1技术分 +1 收起 理由
杜光 + 1 每天提问并回答问题,是对知识的复习和积累.

查看全部评分

2 个回复

倒序浏览
首先:基于 TreeMap 的 NavigableSet 实现。使用元素的自然顺序对元素进行排序,或者根据创建 set 时提供的 Comparator 进行排序,具体取决于使用的构造方法。

学生类实现了Comparable接口,这样它就具备了可比较性,当把对象添加到集合的时候,集合会调用你定你的CompareTo方法。当学生类不具备可比较性的时候,集合会按照自然排序对元素进行排序。

评分

参与人数 1黑马币 +3 收起 理由
杨兴庭 + 3

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马