溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java去重排序之Comparable與Comparator怎么使用

發(fā)布時(shí)間:2023-04-07 10:28:53 來(lái)源:億速云 閱讀:104 作者:iii 欄目:開(kāi)發(fā)技術(shù)

本文小編為大家詳細(xì)介紹“Java去重排序之Comparable與Comparator怎么使用”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“Java去重排序之Comparable與Comparator怎么使用”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來(lái)學(xué)習(xí)新知識(shí)吧。

一、排序與去重

日常工作中,總會(huì)有一些場(chǎng)景需要對(duì)結(jié)果集進(jìn)行一些過(guò)濾。比如,與第三方交互后獲取的結(jié)果集,需要再次排序去重,此時(shí)就會(huì)根據(jù)某個(gè)字段來(lái)去重,又或者某個(gè)字段來(lái)排序。

在Java中,去重的話,我們很容易就想到了Set的特性(無(wú)序無(wú)重),并且TreeSet(有序無(wú)重)還可以指定去重的規(guī)則(去重后一般是升序的結(jié)果集)。

排序的話,我們很容易想到各種排序算法,但Java中已經(jīng)提供了排序的功能,如集合中sort()方法,并且還可以指定排序的字段和升降序。

在此多說(shuō)一句,Set的特性(無(wú)序無(wú)重):

  • 無(wú)序:無(wú)序性不是隨機(jī)性,因?yàn)榉湃雜et中的元素,會(huì)根據(jù)元素的hash值來(lái)決定所放入的位置

  • 無(wú)重:添加元素時(shí) ,會(huì)按照元素的equals()進(jìn)行判斷,false認(rèn)為兩個(gè)元素不等時(shí),才會(huì)添加

二、Comparable與Comparator的使用

public class CompareTest {

    public static void main(String[] args) {
        // 例如:從第三方返回的結(jié)果集
        // 根據(jù)id去重,根據(jù)createTime降序排列
        String result = "["
                + "{ \"id\": 1, \"createTime\": \"2022-12-21 13:23:59\"}"
                + "{ \"id\": 2, \"createTime\": \"2022-11-11 12:43:01\"}"
                + "{ \"id\": 1, \"createTime\": \"2022-12-21 11:20:50\"}"
                + "{ \"id\": 3, \"createTime\": \"2023-01-01 14:30:00\"}"
                + "]";
        JSONArray examList = JSONArray.parseArray(result);
        System.out.println("初始數(shù)據(jù)集:" + examList);

        // 去重,利用set特性
        Comparator<JSONObject> comparator = (a, b) -> Integer.compare(a.getIntValue("id"), b.getIntValue("id"));
        Set<JSONObject> set = new TreeSet<>(comparator);
        examList.forEach(jo -> set.add((JSONObject) jo));
        // 此時(shí)的結(jié)果是,根據(jù)id去重,并且是升序的結(jié)果(自然排序)
        System.out.println("去重結(jié)果:" + set);

        // 此處為了,方便演示Comparable接口的作用,故把JSON映射成實(shí)體類,進(jìn)行實(shí)現(xiàn)接口排序,其實(shí)sorted也可以使用Comparator排序
        List<ExamInfo> collect = set.stream()
                .map(jo -> JSONObject.toJavaObject(jo, ExamInfo.class))
                .sorted()
                .collect(Collectors.toList());
        System.out.println("指定排序結(jié)果:" + collect);
    }

}
public class ExamInfo implements Comparable<ExamInfo> {

    private int id;
    private String createTime;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getCreateTime() {
        return createTime;
    }

    public void setCreateTime(String createTime) {
        this.createTime = createTime;
    }

    @Override
    public String toString() {
        return "ExamInfo{" +
                "id=" + id +
                ", createTime='" + createTime + '\'' +
                '}';
    }

    @Override
    public int compareTo(ExamInfo o) {
        // 降序
        return o.getCreateTime().compareTo(this.createTime);
    }
}

Java去重排序之Comparable與Comparator怎么使用

關(guān)于排序升降序問(wèn)題,Comparable與Comparator中的比較方法的返回值,大于0就交換。

所以參數(shù)順序?yàn)閍,b時(shí):

  • a>b,即a-b>0,因?yàn)轫樞蚴?a,b,交換后,b在前,a在后,排序順序升序,即為自然排序;

 // 升序
 Comparator<JSONObject> comparator = (a, b) -> Integer.compare(a.getIntValue("id"), b.getIntValue("id"));
  • b>a,即b-a>0,因?yàn)轫樞蚴?a,b,交換后,b在前,a在后,排序順序降序。

 	@Override
 	public int compareTo(ExamInfo o) {
        // 降序
        return o.getCreateTime().compareTo(this.createTime);
    }

三、區(qū)別


ComparableComparator
所屬包java.langjava.util
是否為函數(shù)式接口
比較的方法int compareTo(T o)int compare(T o1, T o2)
使用場(chǎng)景比較的對(duì)象,自己可修改比較的對(duì)象,自己不能修改,或者對(duì)象實(shí)現(xiàn)了Comparable接口,但比較規(guī)則不適用

讀到這里,這篇“Java去重排序之Comparable與Comparator怎么使用”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過(guò)才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI