java学习笔记13--比较器(Comparable、Comparator)

分类: JAVA 2013-05-20 23:20 3296人阅读 评论(0) 收藏 举报

Comparable接口的作用

之前Arrays类中存在sort()方法,此方法可以直接对对象数组进行排序。

Comparable接口

可以直接使用java.util.Arrays类进行数组的排序操作,但对象所在的类必须实现Comparable接口,用于指定排序接口。

Comparable接口的定义如下:

public  interface  Comparable<T>{

        public  int compareTo(T  o);

}

此方法返回一个int类型的数据,但是此int的值只能是一下三种:

1:表示大于

-1:表示小于

0:表示相等

要求:定义一个学生类,里面有姓名,年龄,成绩三个属性,要求按成绩由高到低排序,如果成绩相等,则按照年龄由低到高排序。

  1. package com.itmyhome;
  2. import java.util.Arrays;
  3. class Student implements Comparable<Student>{
  4. private String name;
  5. private int age;
  6. private float score;
  7. public Student(String name,int age,float score){
  8. this.name = name;
  9. this.age = age;
  10. this.score = score;
  11. }
  12. @Override
  13. public int compareTo(Student stu) {  //覆写compareTo方法实现排序规则的应用
  14. if(this.score>stu.score){
  15. return -1;
  16. }else if(this.score<stu.score){
  17. return 1;
  18. }else{
  19. if(this.age>stu.age){
  20. return 1;
  21. }else if(this.age<stu.age){
  22. return -1;
  23. }else{
  24. return 0;
  25. }
  26. }
  27. }
  28. public String toString(){
  29. return "姓名:"+this.name+", 年龄:"+this.age+", 成绩:"+this.score;
  30. }
  31. public String getName() {
  32. return name;
  33. }
  34. public void setName(String name) {
  35. this.name = name;
  36. }
  37. public int getAge() {
  38. return age;
  39. }
  40. public void setAge(int age) {
  41. this.age = age;
  42. }
  43. public float getScore() {
  44. return score;
  45. }
  46. public void setScore(float score) {
  47. this.score = score;
  48. }
  49. }
  50. public class T {
  51. public static void main(String[] args) throws Exception{
  52. Student stu[] = {new Student("张三",22,80f)
  53. ,new Student("李四",23,83f)
  54. ,new Student("王五",21,80f)};
  55. Arrays.sort(stu);   //进行排序操作
  56. for (int i = 0; i < stu.length; i++) {
  57. Student s = stu[i];
  58. System.out.println(s);
  59. }
  60. }
  61. }

分析比较器的排序原理

实际上比较器的操作,就是经常听到的二叉树的排序算法。

排序的基本原理:使用第一个元素作为根节点,之后如果后面的内容比根节点小,则放在左子树,如果内容比根节点的内容要大,则放在右子树。

  1. package com.itmyhome;
  2. class BinaryTree {
  3. class Node { // 声明一个节点类
  4. private Comparable data; // 保存具体的内容
  5. private Node left; // 保存左子树
  6. private Node right; // 保存右子树
  7. public Node(Comparable data) {
  8. this.data = data;
  9. }
  10. public void addNode(Node newNode) {
  11. // 确定是放在左子树还是右子树
  12. if (newNode.data.compareTo(this.data) < 0) { // 内容小,放在左子树
  13. if (this.left == null) {
  14. this.left = newNode; // 直接将新的节点设置成左子树
  15. } else {
  16. this.left.addNode(newNode); // 继续向下判断
  17. }
  18. }
  19. if (newNode.data.compareTo(this.data) >= 0) { // 放在右子树
  20. if (this.right == null) {
  21. this.right = newNode; // 没有右子树则将此节点设置成右子树
  22. } else {
  23. this.right.addNode(newNode); // 继续向下判断
  24. }
  25. }
  26. }
  27. public void printNode() { // 输出的时候采用中序遍历
  28. if (this.left != null) {
  29. this.left.printNode(); // 输出左子树
  30. }
  31. System.out.print(this.data + "\t");
  32. if (this.right != null) {
  33. this.right.printNode();
  34. }
  35. }
  36. };
  37. private Node root; // 根元素
  38. public void add(Comparable data) { // 加入元素
  39. Node newNode = new Node(data); // 定义新的节点
  40. if (root == null) { // 没有根节点
  41. root = newNode; // 第一个元素作为根节点
  42. } else {
  43. root.addNode(newNode); // 确定是放在左子树还是放在右子树
  44. }
  45. }
  46. public void print() {
  47. this.root.printNode(); // 通过根节点输出
  48. }
  49. };
  50. public class T2 {
  51. public static void main(String args[]) {
  52. BinaryTree bt = new BinaryTree();
  53. bt.add(8);
  54. bt.add(3);
  55. bt.add(3);
  56. bt.add(10);
  57. bt.add(9);
  58. bt.add(1);
  59. bt.add(5);
  60. bt.add(5);
  61. System.out.println("排序之后的结果:");
  62. bt.print();
  63. }
  64. };

另一种比较器:Compartor

如果一个类已经开放完成,但是在此类建立的初期并没有实现Comparable接口,此时肯定是无法进行对象排序操作的,所以为了解决这一的问题,java又定义了另一个比较器的操作接口 Comparator 此接口定义在java.util包中,接口定义如下:

public  interface  Comparator<T>{

public  int  compare(T o1,T o2);

boolean  equals(Object  obj);

}

MyComparator.java

  1. package com.itmyhome;
  2. import java.util.Comparator;
  3. public class MyComparator implements Comparator<Student> {  //实现比较器
  4. @Override
  5. public int compare(Student stu1, Student stu2) {
  6. // TODO Auto-generated method stub
  7. if(stu1.getAge()>stu2.getAge()){
  8. return 1;
  9. }else if(stu1.getAge()<stu2.getAge()){
  10. return -1;
  11. }else{
  12. return 0;
  13. }
  14. }
  15. }
  1. package com.itmyhome;
  2. import java.util.ArrayList;
  3. import java.util.Arrays;
  4. import java.util.Collections;
  5. import java.util.List;
  6. class Student {
  7. private String name;
  8. private int age;
  9. public Student(String name,int age ){
  10. this.name = name;
  11. this.age = age;
  12. }
  13. public String toString(){
  14. return "姓名:"+this.name+", 年龄:"+this.age;
  15. }
  16. public String getName() {
  17. return name;
  18. }
  19. public void setName(String name) {
  20. this.name = name;
  21. }
  22. public int getAge() {
  23. return age;
  24. }
  25. public void setAge(int age) {
  26. this.age = age;
  27. }
  28. }
  29. public class T {
  30. public static void main(String[] args) throws Exception{
  31. Student stu[] = {new Student("张三",23)
  32. ,new Student("李四",26)
  33. ,new Student("王五",22)};
  34. Arrays.sort(stu,new MyComparator());             //对象数组进行排序操作
  35. List<Student> list = new ArrayList<Student>();
  36. list.add(new Student("zhangsan",31));
  37. list.add(new Student("lisi",30));
  38. list.add(new Student("wangwu",35));
  39. Collections.sort(list,new MyComparator());      //List集合进行排序操作
  40. for (int i = 0; i < stu.length; i++) {
  41. Student s = stu[i];
  42. System.out.println(s);
  43. }
  44. System.out.println("*********");
  45. for (int i=0;i<list.size();i++){
  46. Student s = list.get(i);
  47. System.out.println(s);
  48. }
  49. }
  50. }

java学习笔记13--比较器(Comparable、Comparator)的更多相关文章

  1. java学习笔记(13) —— google GSON 实现json转化方法

    1.配置struts.xml <action name="getGsonAction" class="com.test.action.json.GetGsonAct ...

  2. Java学习笔记-13.创建窗口和程序片

    1.init()方法:程序片第一次被创建,初次运行初始化程序片时调用. start()方法:每当程序片进入web浏览器中,并且允许程序片启动他的常规操作时调用(特殊的程序片被stop()关闭):同样在 ...

  3. Java学习笔记13(面向对象六:super)

    在创建子类对象时,父类的构造方法会先执行,因为子类中所有构造方法的第一行有默认的隐式super();语句 注意:父类构造方法第一行也有隐式的super(); 所有类都有一个"祖宗类" ...

  4. Java学习笔记13(equals()方法;toString()方法)

    equals()方法: equals方法是Object类中的方法:Object是所有类的祖宗,所以所有类都有equals()方法: boolean equals(Object obj); equals ...

  5. 《Java学习笔记(第8版)》学习指导

    <Java学习笔记(第8版)>学习指导 目录 图书简况 学习指导 第一章 Java平台概论 第二章 从JDK到IDE 第三章 基础语法 第四章 认识对象 第五章 对象封装 第六章 继承与多 ...

  6. 0028 Java学习笔记-面向对象-Lambda表达式

    匿名内部类与Lambda表达式示例 下面代码来源于:0027 Java学习笔记-面向对象-(非静态.静态.局部.匿名)内部类 package testpack; public class Test1{ ...

  7. 20145330第五周《Java学习笔记》

    20145330第五周<Java学习笔记> 这一周又是紧张的一周. 语法与继承架构 Java中所有错误都会打包为对象可以尝试try.catch代表错误的对象后做一些处理. 使用try.ca ...

  8. Java学习笔记4

    Java学习笔记4 1. JDK.JRE和JVM分别是什么,区别是什么? 答: ①.JDK 是整个Java的核心,包括了Java运行环境.Java工具和Java基础类库. ②.JRE(Java Run ...

  9. 0032 Java学习笔记-类加载机制-初步

    JVM虚拟机 Java虚拟机有自己完善的硬件架构(处理器.堆栈.寄存器等)和指令系统 Java虚拟机是一种能运行Java bytecode的虚拟机 JVM并非专属于Java语言,只要生成的编译文件能匹 ...

随机推荐

  1. Gora_百度百科

    Gora_百度百科     Gora    编辑    目录         1什么是Apache Gora         2为什么要使用Apache Gora         3Gora的一个源代 ...

  2. HDU-1664-Different Digits(BFS)

    Problem Description Given a positive integer n, your task is to find a positive integer m, which is ...

  3. OC中多线程的一些概念

    1.进程1.1>进程是指在系统中正在运行的一个应用程序(同时打开QQ和Xcode,系统会分别启动2个进程)1.2>每个进程之间是独立的,每个进程均运行在其专用的且受保护的内存空间内 2.线 ...

  4. WCF技术剖析之十七:消息(Message)详解(上篇)

    原文:WCF技术剖析之十七:消息(Message)详解(上篇) [爱心链接:拯救一个25岁身患急性白血病的女孩[内有苏州电视台经济频道<天天山海经>为此录制的节目视频(苏州话)]]消息交换 ...

  5. c#实现Javascript的encodeURIComponent()函数

    原文  c#实现Javascript的encodeURIComponent()函数 国内外各搜索引擎,均用JavaScript的encodeURIComponent()函数对搜索关键字进行编码,终于找 ...

  6. 如何捕获Wince下form程序的全局异常

    前言 上两篇文章我们总结了在winform程序下如何捕获全局的异常.那么同样的问题,在wince下我们如何来处理呢?用相同的代码来处理可以吗? 答案是否定的,上面的方案1完全不能解决wince下的情况 ...

  7. Table中的JCheckBox TableHeader的全选(全反选)功能

    菜鸟学习ing class CheckDefaultModel extends DefaultTableModel /* * To change this template, choose Tools ...

  8. 为什么出现Wide character in print at a14.pl line 41

    [root@wx03 ~]# cat a14.pl use Net::SMTP; use LWP::UserAgent; use HTTP::Cookies; use HTTP::Headers; u ...

  9. php导出excel数据

    提供两种导出excel方法 1 最简单的导出excel header('Content-Type: application/vnd.ms-excel'); //设置文件类型   也可以将 vnd.ms ...

  10. 通过 Spring RestTemplate 调用带请求体的 Delete 方法(Delete With Request Body)

    Spring 框架的RestTemplate 类定义了一些我们在通过 java 代码调用 Rest 服务时经常需要用到的方法,使得我们通过 java 调用 rest 服务时更加方便.简单.但是 Res ...