基于|基于 React + Redux/Mobx 搞定复杂项目状态管理

download:基于 React + Redux/Mobx 搞定复杂项目状态管理 1.字面含义不同 我们先从二者的字面含义来理解它,Comparable 翻译为中文是“比较”的意思,而 Comparator 是“比较器”的意思。Comparable 是以 -able 结尾的,表示它自身具备着某种能力,而 Comparator 是以 -or 结尾,表示自身是比较的参与者,这是从字面含义先来理解二者的不同。
2.用法不同 二者都是顶级的接口,但拥有的方法和用法是不同的,下面我们分别来看。
2.1 Comparable
Comparable 接口只有一个方法 compareTo,实现 Comparable 接口并重写 compareTo 方法就可以实现某个类的排序了,它支持 Collections.sort 和 Arrays.sort 的排序。
?
在我们没有使用 Comparable 时,程序的执行是这样的:

import lombok.Getter; import lombok.Setter; import lombok.ToString; import java.util.ArrayList; import java.util.List; public class ComparableExample { public static void main(String[] args) { // 创建对象 Person p1 = new Person(1, 18, "Java"); Person p2 = new Person(2, 22, "MySQL"); Person p3 = new Person(3, 6, "Redis"); // 添加到集合 List【基于|基于 React + Redux/Mobx 搞定复杂项目状态管理】 list = new ArrayList<>(); list.add(p1); list.add(p2); list.add(p3); // 打印集合信息 list.forEach(p -> System.out.println(p.getName() + ":" + p.getAge())); } }// 以下 set/get/toString 都使用的是 lombok 提供的注解 @Getter @Setter @ToString class Person { private int id; private int age; private String name; public Person(int id, int age, String name) { this.id = id; this.age = age; this.name = name; } }

程序执行结果如下:
从上图可以看出,当自定义类 Person 没有实现 Comparable 时,List 集合是没有排序的,只能以元素的插入顺序作为输出的顺序。
然而这个时候,老板有一个需求:需要根据 Person 对象的年龄 age 属性进行倒序,也就是根据 age 属性从大到小进行排序,这个时候就可以请出,我们本文的主角:Comparable 出场了。
Comparable 的使用是在自定义对象的类中实现 Comparable 接口,并重写 compareTo 方法来实现自定义排序规则的,具体实现代码如下:
import lombok.Getter; import lombok.Setter; import lombok.ToString; import java.util.ArrayList; import java.util.Collections; import java.util.List; public class ComparableExample { public static void main(String[] args) { // 创建对象 Person p1 = new Person(1, 18, "Java"); Person p2 = new Person(2, 22, "MySQL"); Person p3 = new Person(3, 6, "Redis"); // 添加对象到集合 List list = new ArrayList<>(); list.add(p1); list.add(p2); list.add(p3); // 进行排序操作(根据 Person 类中 compareTo 中定义的排序规则) Collections.sort(list); // 输出集合中的顺序 list.forEach(p -> System.out.println(p.getName() + ":" + p.getAge())); } }

    推荐阅读