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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 王瀛 高级黑马   /  2013-6-4 20:14  /  1884 人查看  /  6 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

rt,毕老师java基础day15-02 , 4分20秒左右

毕老师向TreeSet中传入了四个Student对象,运行后弹出的错误提示是在26行。之后将26至28行的传入元素注释掉只留一个传入元素后,代码运行是没有问题的。


但是,我完全按照毕老师的行号敲代码操作的时候,传入四个对象时,弹出的错误提示是在25行。之后我也将26至28行的传入元素注释掉,只留一个元素。运行还是提示错误。


想问下,这里出错是随机的,还是说我个人的原因。。。。

评分

参与人数 1技术分 +1 收起 理由
Sword + 1

查看全部评分

6 个回复

正序浏览
个人原因,重打一遍吧
回复 使用道具 举报
神之梦 发表于 2013-6-4 21:34
我找了下,楼主写的代码应该是没问题的
我对比了下老师的提示和我们的提示发现,多了一个东东

嗯,我现在用的 jdk 7u21 x64 版,不知是不是 6-7的时候对其进行了改动。。。。

回复 使用道具 举报

我找了下,楼主写的代码应该是没问题的
我对比了下老师的提示和我们的提示发现,多了一个东东

我在想是不是我们现在的版本对其进行改动??????(老师使用的6.几几版本,我现在使用的是7.几几版本)
由于自身能力有限,这个我也解答不了,等大神吧。。。。。。。。。。。。。。。。。
回复 使用道具 举报
神之梦 发表于 2013-6-4 20:47
应该是个人原因,把你代码贴出来看下,要不你再仔细查找下
出现这个错误的原因是因为Student这个类本身不具 ...
  1. import java.util.*;

  2. /*
  3. Set:无序,不可以重复元素。
  4.         |--HashSet:数据结构是哈希表。线程是非同步的。
  5.                                 保证元素唯一性的原理:判断元素的hashCode值是否相同。
  6.                                 如果相同,还继续会判断元素的equals方法是否为true。
  7.                                
  8.         |--TreeSet:可以对Set集合中的元素进行排序。
  9.                                


  10. 需求:
  11. 往TreeSet集合中存储自定义对象学生。
  12. 想按照学生的年龄进行排序。

  13. */

  14. class TreeSetDemo
  15. {
  16.         public static void main(String[] args)
  17.         {
  18.                 TreeSet ts = new TreeSet();

  19.                 ts.add(new Student("lisi02",22));//<-----------------------------------25行
  20.                 //ts.add(new Student("lisi007",20));
  21.                 //ts.add(new Student("lisi09",19));
  22.                 //ts.add(new Student("lisi01",40));
  23.                
  24.                 Iterator it = ts.iterator();
  25.                 while (it.hasNext())
  26.                 {
  27.                         Student stu = (Student)it.next();
  28.                 }
  29.         }
  30. }


  31. class Student
  32. {
  33.         private String name;
  34.         private int age;

  35.         Student(String name,int age)
  36.         {
  37.                 this.name = name;
  38.                 this.age = age;
  39.         }
  40.        
  41.         public String getName()
  42.         {
  43.                 return name;

  44.         }
  45.         public int getAge()
  46.         {
  47.                 return age;
  48.         }
  49. }
复制代码
回复 使用道具 举报
神之梦 发表于 2013-6-4 20:47
应该是个人原因,把你代码贴出来看下,要不你再仔细查找下
出现这个错误的原因是因为Student这个类本身不具 ...

按照使Student类实现Comparable接口,复写compareTo方法的方式弄好后,可以排序

但是最开始的传入一个元素报错还是不晓得怎么弄的。。。

我把代码复原到出错时候的样子,你帮我看看。。。。
回复 使用道具 举报
应该是个人原因,把你代码贴出来看下,要不你再仔细查找下
出现这个错误的原因是因为Student这个类本身不具备比较性,当你向集合中添加第二个元素时,因为Tree是要对元素进行排序的,
而这种排序调用的是对像的compareTo这个方法,因为Student这个对象中没有这个方法,也就是说Student没有实现Comparable这个接口,因为不具备比较性。
所以存第二个元素时,它要和第一个元素进行比较,来决定顺序,然后你没有告诉他们应该按照什么规则来排序,这样Tree集合就不能对其进行排序,这样就报错了。。
而第一个存入的元素,因为只有一个元素,不存在与其他元素进行比较,所以老师把其他的都注释掉,只剩下一个的时候,是不会报错的。。。。

评分

参与人数 1技术分 +1 收起 理由
Sword + 1

查看全部评分

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