java.lang源码_从零开始读JAVA源码04-java.lang.String

implements Serializable, Comparable, CharSequence。

今天写一下 String类的 实现接口定义

Comparable

什么是Comparable接口

此接口强行对实现它的每个类的对象进行整体排序。此排序被称为该类的自然排序 ,类的 compareTo 方法被称为它的自然比较方法 。实现此接口的对象列表(和数组)可以通过 Collections.sort (和 Arrays.sort )进行自动排序。实现此接口的对象可以用作有序映射表中的键或有序集合中的元素,无需指定比较器。 强烈推荐(虽然不是必需的)使自然排序与 equals 一致。所谓与equals一致是指对于类 C 的每一个 e1 和 e2 来说,当且仅当 (e1.compareTo((Object)e2) == 0) 与e1.equals((Object)e2) 具有相同的布尔值时,类 C 的自然排序才叫做与 equals 一致 。

可以实现排序的,如下效果:

ArrayList arr = new ArrayList();

arr.add("A");

arr.add("C");

arr.add("B");

System.out.println(arr);

//rs [A, C, B]

Collections.sort(arr);

System.out.println(arr);

//rs [A, B, C]

可以排序的原因是实现了

排序通过 compareTo 方法

System.out.println("A".compareTo("A"));//rs:0

System.out.println("A".compareTo("B"));//rs: -1

System.out.println("C".compareTo("A"));//rs: 2

对于一个普通类实现Comparable接口,重写

class Student implements Comparable{

private String name;

private int ranking;

public Student(String name, int ranking){

this.name = name;

this.ranking = ranking;

}

public String toString(){

return this.name + ":" + this.ranking;

}

public int compareTo(Object o){

Student s = (Student)(o);

return this.ranking - s.ranking;

}

}

public class Compare2{

public static void f(){

ArrayList arr = new ArrayList();

arr.add(new Student("Jack",10));

arr.add(new Student("Bill",23));

arr.add(new Student("Rudy",7));

System.out.println(arr);

Collections.sort(arr);

System.out.println(arr);

}

}

注意重写的compareTo(Object o)方法内.  根据Student的ranking成员来比较的, 也就是说跟姓名无关了.

这时再编译执行, 就能见到List容器内的Student对象已经根据ranking来排序了.

输出:

[java] [Jack:10, Bill:23, Rudy:7]

[java] [Rudy:7, Jack:10, Bill:23]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值