package java1;
/**
* @author Baobao
* @create 2021-08-05 17:59
*/
public class Goods implements Comparable{
private String name;
private double price;
public Goods(String name, double price) {
this.name = name;
this.price = price;
}
public Goods(){
}
public void setName(String name) {
this.name = name;
}
public void setPrice(double price) {
this.price = price;
}
public String getName() {
return name;
}
public double getPrice() {
return 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) o).price){
return 1;
}else if(this.price<((Goods) o).price){
return -1;
}else{
return 0;
}
}
throw new RuntimeException();
}
}
package java1;
import org.junit.Test;
import java.util.Arrays;
import java.util.Comparator;
/**
* Java中的对象正常情况下只能进行==和!=的比较
* 但是在开发场景中又需要对多个对象进行排序
* 即,需要比较对象的大小
* 就需要使用两个接口中的任何一个:Comparable or Comparator
*
* Comparable的使用:
*
*
* @author Baobao
* @create 2021-08-05 17:48
*/
public class CompareTest {
/*
Comparable的使用举例:
String或者是包装类,实现了Comparable接口,重写了CompareTo方法,给出了比较两个对象大小的判定方式。
重写CompareTo的规则:
CompareTp(obj);如果this大于obj,返回正整数;小于obj,返回负数,等于时返回0
对于自定义类来说,如果需要排序,我们可以让自定义类去实现Comparable接口
指明如何排序,称为自然排序
*/
@Test
public void test1(){
String [] arr=new String[]{"AA","CC","MM","GG","JJ","DD","KK"};
Arrays.sort(arr);
System.out.println(Arrays.toString(arr));
}
@Test
public void compareGood(){
Goods[]arr=new Goods[4];
arr[0]=new Goods("lianxiang",34);
arr[1]=new Goods("dell",43);
arr[0]=new Goods("mi",12);
arr[0]=new Goods("huawei",65);
Arrays.sort(arr);
System.out.println(arr.toString());
}
/*
Comparator:定制排序
相当于临时性的
当前元素类型没有实现Comparable接口,又不方便修改代码
或者实现了Comparable接口,但是不适用于此时的规则时
考虑用Comparator来排序
*/
@Test
public void test03(){
String [] arr=new String[]{"AA","CC","MM","GG","JJ","DD","KK"};
//字符串从大到小排列
Arrays.sort(arr, new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
return -o1.compareTo(o2);
}
});
System.out.println(Arrays.toString(arr));
}
}