- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
?
56、TreeMap和TreeSet在排序时如何比较元素?Collections工具类中的sort()方法如何比较元素?
答:TreeSet要求存放的对象所属的类必须实现Comparable接口,该接口提供了比较元素的compareTo()方法,当插入元素时会回调该方法比较元素的大小。TreeMap要求存放的键值对映射的键必须实现Comparable接口从而根据键对元素进行排序。Collections工具类的sort方法有两种重载的形式,第一种要求传入的待排序容器中存放的对象比较实现Comparable接口以实现元素的比较;第二种不强制性的要求容器中的元素必须可比较,但是要求传入第二个参数,参数是Comparator接口的子类型(需要重写compare方法实现元素的比较),相当于一个临时定义的排序规则,其实就是通过接口注入比较元素大小的算法,也是对回调模式的应用(Java中对函数式编程的支持)。?
例子1:
?
public class Student implements ComparableStudent { ? ?private String name; ? ? ? ?// 姓名
? ?private int age; ? ? ? ? ? ?// 年龄
? ?public Student(String name, int age) { ? ? ? ? = name; ? ? ? ?this.age = age;
? ?} ? ?@Override
? ?public String toString() { ? ? ? ?return Student [name= + name + , age= + age + ];
? ?} ? ?@Override
? ?public int compareTo(Student o) { ? ? ? ?return this.age - o.age; // 比较年龄(年龄的升序)
? ?}
}
import java.util.Set;
import java.util.TreeSet;class Test01 { ? ?public static void main(String[] args) {
? ? ? ?SetStudent set = new TreeSet(); ? ? ? ?// Java 7的钻石语法(构造器后面的尖括号中不需要写类型)
? ? ? ?set.add(new Student(Hao LUO, 33)); ? ? ? ?set.add(new Student(XJ WANG, 32)); ? ? ? ?set.add(new Student(Bruce LEE, 60)); ? ? ? ?set.add(new Student(Bob YANG, 22)); ? ? ? ?for(Student stu : set) {
? ? ? ? ? ?System.out.println(stu);
? ? ? ?}// ? ? ? ?输出结果: // ? ? ? ?Student [name=Bob YANG, age=22]// ? ? ? ?Student [name=XJ WANG, age=32]// ? ? ? ?Student [name=Hao LUO, age=33]// ? ? ? ?Student [name=Bruce LEE, age=60]
? ?}
}
?
例子2:
?
public class Student { ? ?private String name; ? ? // 姓名
? ?private int age; ? ? ? ? // 年龄
? ?public Student(String name, int age) { ? ? ? ? = name; ? ? ? ?this.age = age;
? ?} ? ?/**
? ? * 获取学生姓名
? ? */
? ?public String getName() { ? ? ? ?return name;
? ?} ? ?/**
? ? * 获取学生年龄
? ? */
? ?public int getAge() { ? ? ? ?return age;
? ?}
? ?@Override ? ?public String toString() { ? ? ? ?return Student [name= + name + , age= + age + ];
? ?}
}
import java.util.ArrayList;
import java.util.Collections;
import java
您可能关注的文档
最近下载
- 三年级语文上册习作八:那次玩得真高兴课件(共26张PPT).pptx VIP
- 六年级人教版小学英语-阅读理解专题练习(及答案).doc VIP
- 污水厂年度工作计划(模板).doc
- ECOVACS 科沃斯 净化机器人沁宝 AIRBOT Z1产品使用说明书.pdf
- 24秋人教PEP英语三年级上册 Unit 1 Making friends 单元教学课件.pptx
- 2022年防雷检测职业技能竞赛综合知识试题库大全-下(判断题部分).pdf
- 装修公司工程部品控管理:材料堆放保护规范.docx
- 2023年长沙市事业单位公开招聘考试真题.docx
- 万孚生物-市场前景及投资研究报告:POCT龙头,技术平台全覆盖,国内外双核驱动.pdf VIP
- 全数字交流伺服驱动系统KT270-H系列(V1.0)使用手册.PDF
文档评论(0)