package com.yhqtv.java;

 import org.junit.Test;

 import java.util.Arrays;
import java.util.Comparator; /*
* 一,说明:java中的对象,正常情况下,只能进行比较:==或!=,不能使用>或者<的
* 但是在开发场景中,我们需要对多个对象进行排序,言外之意,就是需要比较对象的大小。
* 如何实现?使用两个接口中的任何一个:Comparable或者Comparator
*
* 二、Comparable 接口与Comparator的使用的对比
* Comparable接口的方式一旦一定,保证Compa接口实现类的对象在任何位置都可以比较大小
* Comparator接口属于临时性的比较。
*
* @author XMKJ yhqtv.com Email:yhqtv@qq.com
* @create 2020-05-01-17:30
*
*/
public class CompareTest {
/*
* Comparable接口的使用举例:
* 1.像String、包装类等实现了Comparable接口,重写了compareTo(obj)方法,给出了比较两个对象大小的方式
* 2.像String、包装类重写compareTo()方法以后,进行了从小到大的排序
* 3.重写compareTo(obj)的规则:
* 如果当前对象this大于形参对象obj,则返回正整数,
* 如果当前对象this小于形参对象obj,则返回负数
* 如果当前对象this等于形参对象obj,则返回零
* 4.对于自定义类来说,如果需要排序,我们可以让自定义类实现Comparable接口,重写
* compareTo(obj)方法。在compareTo(obj)方法中指明如何排序
* */
@Test
public void test1() {
String[] arr = new String[]{"AA", "CC", "MM", "GG", "JJ", "DD", "LL"};
Arrays.sort(arr);
System.out.println(Arrays.toString(arr));
} @Test
public void test2() {
Goods[] g = new Goods[4];
g[0] = new Goods("火柴", 2.32);
g[1] = new Goods("联想", 1.32);
g[2] = new Goods("戴尔", 8.32);
g[3] = new Goods("苹果", 3.32); Arrays.sort(g); System.out.println(Arrays.toString(g));
} /*
* Comparator接口的使用:定制排序
* 1.背景
* 当元素的类型没有实现java.lang.Comparable接口而又不方便修改代码,
* 或者实现了java.lang.Comparable接口的排序规则不适合当前的操作,
* 那么可以考虑使用Comparator的对象来排序
* 2.重写compare(Object o1,Object o2)方法,比较o1和o2的大小;
* 如果方法返回正整数,则表示o1大于o2;
* 如果返回0,表示相等;
* 返回负整数,表示o1小于o2.
* */
@Test
public void test3() {
String[] arr = new String[]{"AA", "CC", "MM", "GG", "JJ", "DD", "LL"};
Arrays.sort(arr, new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
if (o1 instanceof String && o2 instanceof String) {
String s1 = (String) o1;
String s2 = (String) o2; return -s1.compareTo(s2);
} // return 0;
throw new RuntimeException("输入数据类型不一致");
}
});
System.out.println(Arrays.toString(arr));
} @Test
public void test4() {
Goods[] g = new Goods[4];
g[0] = new Goods("联想", 2.32);
g[1] = new Goods("联想", 1.32);
g[2] = new Goods("戴尔", 8.32);
g[3] = new Goods("苹果", 3.32); Arrays.sort(g, new Comparator() {
// 指明商品比较大小的方式:按照产品名称从低到高排序,再按照价格从高到底排序
@Override
public int compare(Object o1, Object o2) {
if (o1 instanceof Goods && o2 instanceof Goods) {
Goods g1=(Goods)o1;
Goods g2=(Goods)o2;
if(g1.getName().equals(g2.getName())){
return -Double.compare(g1.getPrice(),g2.getPrice());
}else{
return g1.getName().compareTo(g2.getName());
}
}
throw new RuntimeException("输入数据类型不一致");
}
}); System.out.println(Arrays.toString(g));
}
}
 package com.yhqtv.java;

 /*
* @author XMKJ yhqtv.com Email:yhqtv@qq.com
* @create 2020-05-01-18:09
*
*/
public class Goods implements Comparable{ private String name;
private double price; public Goods() {
} public Goods(String name, double price) {
this.name = name;
this.price = price;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public double getPrice() {
return price;
} public void setPrice(double price) {
this.price = price;
} @Override
public String toString() {
return "Goods{" +
"name='" + name + '\'' +
", price=" + price +
'}';
}
// 指明商品比较大小的方式
@Override
public int compareTo(Object o) {
if(o instanceof Goods){
Goods goods=(Goods) o;
// 方式一
if(this.price>goods.price){
return 1;
}else if(this.price<goods.price){
return -1;
}else {
return 0;
}
// 方式二;
// return Double.compare(this.price,goods.price);
}
// return 0;
throw new RuntimeException("传入的数据类型不一致!");
}
}

Comparable 接口与Comparator的使用的对比的更多相关文章

  1. Java中实现对象的比较:Comparable接口和Comparator接口

    在实际应用中,我们往往有需要比较两个自定义对象大小的地方.而这些自定义对象的比较,就不像简单的整型数据那么简单,它们往往包含有许多的属性,我们一般都是根据这些属性对自定义对象进行比较的.所以Java中 ...

  2. Java6.0中Comparable接口与Comparator接口详解

    Java6.0中Comparable接口与Comparator接口详解 说到现在,读者应该对Comparable接口有了大概的了解,但是为什么又要有一个Comparator接口呢?难道Java的开发者 ...

  3. Java:实现对象的比较 comparable接口和comparator接口

    在实际应用中,我们往往有需要比较两个自定义对象大小的地方.而这些自定义对象的比较,就不像简单的整型数据那么简单,它们往往包含有许多的属性,我们一般都是根据这些属性对自定义对象进行比较的.所以Java中 ...

  4. Java—集合框架 Collections.sort()、Comparable接口和Comparator接口

    Collentions工具类--java.util.Collections Collentions是Java集合框架中,用来操作集合对象的工具类,也是Java集合框架的成员,与List.Map和Set ...

  5. Comparable接口与Comparator接口的比较————总结

    之前的两篇文章主要学习了Comparable接口和Comparator接口的学习.既然已经学习完了,现在就趁热打铁,进行总结吧! Comparable接口和Comparator接口的共同点: 1. 都 ...

  6. Comparable接口与Comparator接口的区别

    1. Comparator 和 Comparable 相同的地方 他们都是java的一个接口, 并且是用来对自定义的class比较大小的, 什么是自定义class: 如 public class Pe ...

  7. Java中的Comparable接口和Comparator接口

    Comparator位于包java.util下,比较器,是在集合外部定义排序.Comparable位于包java.lang下,代表当前对象可比较的,是在集合内部实现排序. Comparable代表一个 ...

  8. Java之Comparable接口和Comparator接口

    Comparable & Comparator 都是用来实现集合中元素的比较.排序的: Comparable 是在集合内部定义的方法实现的排序: Comparator 是在集合外部实现的排序: ...

  9. 选择Comparable接口还是Comparator

    个人理解: 如果我本身知道这个类的对象我要用来比较,那么就拿这个类实现Comparable接口(compareTo(Object o) 方法).如果我本身没有预料到我要比较这个类的对象,那么,我可以建 ...

随机推荐

  1. Java并发基础05. 传统线程同步通信技术

    先看一个问题: 有两个线程,子线程先执行10次,然后主线程执行5次,然后再切换到子线程执行10,再主线程执行5次--如此往返执行50次. 看完这个问题,很明显要用到线程间的通信了, 先分析一下思路:首 ...

  2. springBoot配置文件属性注入

    以一个微信公众号开发为例,注入微信appid 1.在application.properites文件中定义属性 #===================微信相关=============#公众号wxp ...

  3. python:列表生成式的学习

    看个例子: # 定义一个列表 l=[1,2,3,4,5] #()用于创建一个list,结果依次返回列表l的元素的平方,返回list s=[i*i for i in l] # 打印列表s print(s ...

  4. js获取dom节点之 id 获取

    在JavaScript中,标准的id选择器调用语法是: document.getElementById('myid').style.width = pc + "%"; 但是,今天发 ...

  5. Java引用的分类

    Java引用分为强引用.软引用.弱引用和虚引用. 强引用就是指在程序代码中普遍存在的,类似“Object obj = new Object()”这类的引用,只要强引用还存在,垃圾收集器永远不会回收掉被 ...

  6. 微信小程序(黑马优购)完成!!{10天}

    微信小程序(黑马优购)完成!!{10天} 项目技术点: wxml, json, wxss, js, mina框架 附上视频链接添加链接描述

  7. 浏览器判断兼容IE

    很多时候IE浏览器的兼容性问题总是让人很头疼,或许是样式的或许是脚本的.总之因为IE的低版本问题会引发各种各样的问题出来. function isUnderIE10() {//IE 6,7,8,9 i ...

  8. Java JUC之Atomic系列12大类实例讲解和原理分解

    Java JUC之Atomic系列12大类实例讲解和原理分解 2013-02-21      0个评论       作者:xieyuooo 收藏    我要投稿 在java6以后我们不但接触到了Loc ...

  9. Java 理论与实践: 流行的原子

    Java 理论与实践: 流行的原子 新原子类是 java.util.concurrent 的隐藏精华 在 JDK 5.0 之前,如果不使用本机代码,就不能用 Java 语言编写无等待.无锁定的算法.在 ...

  10. 数据结构和算法(Golang实现)(24)排序算法-优先队列及堆排序

    优先队列及堆排序 堆排序(Heap Sort)由威尔士-加拿大计算机科学家J. W. J. Williams在1964年发明,它利用了二叉堆(A binary heap)的性质实现了排序,并证明了二叉 ...