国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 Java Java入門 java中的比較器comparable和Comparator的區(qū)別

java中的比較器comparable和Comparator的區(qū)別

Nov 27, 2019 pm 01:20 PM
comparable comparator java 差別 比較器

java中的比較器comparable和Comparator的區(qū)別

Comparable比較器

Comparable 位於java.lang 套件下,本質上是一個內比較器,實作了Comparable 的類別可以自己比較,至於比較的結果如何則需要依賴自然比較方法compareTo 的實作。

compareTo 的回傳值有 -1、0、1。若比較者大於被比較者,那麼回傳1,等於則回傳0,小於返回-1。

Collections.sortArrays.sort 可以自動對實作 Comparable 的物件進行排序。

免費線上學習影片推薦:java學習

範例如下,我們建立一個 node 對象,並透過 node 物件之間的比較驗證 Comparable 的用法。

node 物件的實作如下:

public class Node implements Comparable<Object>{
	
	private int num;
	
	private String name;

	@Override
	public String toString() {
		return "num=" + num + " name=" + name;
	}

	public Node(int num, String name) {
		super();
		this.num = num;
		this.name = name;
	}

	public Node() {
		super();
	}

	public int getNum() {
		return num;
	}

	public void setNum(int num) {
		this.num = num;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}
	
	@Override
    public int compareTo(Object o) {
		Node node = (Node)o;
        return this.num - node.getNum();
    }
}

可以看到,我們?yōu)?Node 實作了 Comparable 接口,並且重寫了 compareTo 方法。

先測試一下,我們建立10個 Node 物件並加入到 List 中,然後把順序打亂。

public class MyTest {

	public static void main(String[] args) {
		List<Node> list = new ArrayList<Node>();
		for(int i = 0;i < 10;i++) {
			list.add(new Node(i,"node"));
		}
		//打亂順序
		Collections.shuffle(list);
		for (Node node : list) {
			System.out.println(node);
		}
	}
}

顯示結果如下:

num=7 name=node
num=0 name=node
num=5 name=node
num=9 name=node
num=6 name=node
num=3 name=node
num=4 name=node
num=8 name=node
num=1 name=node
num=2 name=node

現(xiàn)在輸出是亂序的,接下來我們使用 Collections.sort 對其進行排序。

public class MyTest {

	public static void main(String[] args) {
		List<Node> list = new ArrayList<Node>();
		for(int i = 0;i < 10;i++) {
			list.add(new Node(i,"node"));
		}
		//打亂順序
		Collections.shuffle(list);
		Collections.sort(list);
		for (Node node : list) {
			System.out.println(node);
		}
	}
}

Collections.sort 其實是按compareTo 方法中的定義進行比較,我們之前定義了按照num 的升序進行排序,現(xiàn)在排序結果如下:

num=0 name=node
num=1 name=node
num=2 name=node
num=3 name=node
num=4 name=node
num=5 name=node
num=6 name=node
num=7 name=node
num=8 name=node
num=9 name=node

Comparator比較器

Comparator 位於java.util 套件下,本質上是一個外比較器。若一個類別內部未實作 Comparable 又或實作了 Comparable 但該比較方式不是自己想要的,我們可以考慮實作 Comparator。 Comparator 介面裡有一個 compare 方法,使用方法與 Comparable 中的 compareTo 相同。

我們需要將 Comparator 傳遞給排序方法,以便對排序順序進行控制。我們可以查看幾個排序方法的使用方法,發(fā)現(xiàn)可以傳入一個 Comparator 參數(shù)。

Collections.sort(List<T> list, Comparator<? super T> c);
Arrays.sort(T[] a, Comparator<? super T> c);

修改我們先前的 Node 對象,不再實作 Comparable 。

public class Node{
	
	private int num;
	
	private String name;

	@Override
	public String toString() {
		return "num=" + num + " name=" + name;
	}

	public Node(int num, String name) {
		super();
		this.num = num;
		this.name = name;
	}

	public Node() {
		super();
	}

	public int getNum() {
		return num;
	}

	public void setNum(int num) {
		this.num = num;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}
	
}

我們嘗試透過傳入一個 Comparator 來實現(xiàn)降序排序。

public class MyTest {

	public static void main(String[] args) {
		List<Node> list = new ArrayList<Node>();
		for(int i = 0;i < 10;i++) {
			list.add(new Node(i,"node"));
		}
		//打亂順序
		Collections.shuffle(list);
		
		Collections.sort(list, new Comparator<Node>() {
            @Override
            public int compare(Node o1, Node o2) {
                return o2.getNum()-o1.getNum();
            }
        });
		
		for (Node node : list) {
			System.out.println(node);
		}
	}
}

結果如下:

num=9 name=node
num=8 name=node
num=7 name=node
num=6 name=node
num=5 name=node
num=4 name=node
num=3 name=node
num=2 name=node
num=1 name=node
num=0 name=node

Comparator 實作了逆序比較。

總結

Comparable 是內比較器,Comparator 是外比較器,如果類別沒有實作 Comparable 介面但是需要對其進行排序,我們可以考慮使用 Comparator 。從另一個角度來看,使用 Comparable 介面的耦合性大於 Comparator ,因為當我們需要對比較演算法進行修改的時候還需要修改 Comparable 的實作類別。

本文來自java快速入門欄目,歡迎大家一起來討論學習!

以上是java中的比較器comparable和Comparator的區(qū)別的詳細內容。更多資訊請關注PHP中文網(wǎng)其他相關文章!

本網(wǎng)站聲明
本文內容由網(wǎng)友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發(fā)現(xiàn)涉嫌抄襲或侵權的內容,請聯(lián)絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

了解比特幣市場訂單與限制訂單:詳細教程 了解比特幣市場訂單與限制訂單:詳細教程 Jul 10, 2025 pm 09:03 PM

在數(shù)字貨幣交易的世界裡,理解並熟練運用不同的訂單類型是交易成功的關鍵。這就像是駕駛車輛需要掌握油門和剎車一樣基本。市場訂單和限制訂單是所有交易者必須掌握的兩種最基礎且強大的工具。無論您是在幣安Binance、歐易OKX、Huobi火幣還是Gate.io芝麻開門這樣的主流交易平臺進行操作,它們都構成了您執(zhí)行買賣策略的核心。

USDC、DAI、TUSD區(qū)別與優(yōu)缺點對比(最近更新) USDC、DAI、TUSD區(qū)別與優(yōu)缺點對比(最近更新) Jul 10, 2025 pm 09:09 PM

USDC、DAI和TUSD的核心區(qū)別在於發(fā)行機制、抵押資產和風險特徵。 1.USDC是中心化穩(wěn)定幣,由Circle發(fā)行,以現(xiàn)金和短期國債為抵押,優(yōu)點是合規(guī)透明、流動性強、穩(wěn)定性高,但存在中心化審查和單點故障風險;2.DAI是去中心化穩(wěn)定幣,通過MakerDAO協(xié)議生成,抵押品為加密資產,具備抗審查、鏈上透明、無需許可等優(yōu)勢,但也面臨系統(tǒng)性風險、對中心化資產依賴及復雜性問題;3.TUSD是中心化穩(wěn)定幣,強調實時鏈上儲備證明,提供更高頻透明度驗證,但市場份額較小,流動性較弱。三者在抵押物類型、去中心化

Java可選示例 Java可選示例 Jul 12, 2025 am 02:55 AM

Optional能清晰表達意圖並減少null判斷的代碼噪音。 1.Optional.ofNullable是處理可能為null對象的常用方式,如從map中取值時可結合orElse提供默認值,邏輯更清晰簡潔;2.通過鍊式調用map實現(xiàn)嵌套取值,安全地避免NPE,任一環(huán)節(jié)為null則自動終止並返回默認值;3.filter可用於條件篩選,滿足條件才繼續(xù)執(zhí)行後續(xù)操作,否則直接跳到o??rElse,適合輕量級業(yè)務判斷;4.不建議過度使用Optional,如基本類型或簡單邏輯中其反而增加複雜度,部分場景直接返回nu

如何在Java的地圖上迭代? 如何在Java的地圖上迭代? Jul 13, 2025 am 02:54 AM

遍歷Java中的Map有三種常用方法:1.使用entrySet同時獲取鍵和值,適用於大多數(shù)場景;2.使用keySet或values分別遍歷鍵或值;3.使用Java8的forEach簡化代碼結構。 entrySet返回包含所有鍵值對的Set集合,每次循環(huán)獲取Map.Entry對象,適合頻繁訪問鍵和值的情況;若只需鍵或值,可分別調用keySet()或values(),也可在遍歷鍵時通過map.get(key)獲取值;Java8中可通過Lambda表達式使用forEach((key,value)-&gt

如何修復java.io.notserializable Exception? 如何修復java.io.notserializable Exception? Jul 12, 2025 am 03:07 AM

遇到java.io.NotSerializableException的核心解決方法是確保所有需序列化的類實現(xiàn)Serializable接口,並檢查嵌套對象的序列化支持。 1.給主類添加implementsSerializable;2.確保類中自定義字段對應的類也實現(xiàn)Serializable;3.用transient標記不需要序列化的字段;4.檢查集合或嵌套對像中的非序列化類型;5.查看異常信息定位具體哪個類未實現(xiàn)接口;6.對無法修改的類考慮替換設計,如保存關鍵數(shù)據(jù)或使用可序列化的中間結構;7.考慮改

Java中的可比較與比較器 Java中的可比較與比較器 Jul 13, 2025 am 02:31 AM

在Java中,Comparable用於類內部定義默認排序規(guī)則,Comparator用於外部靈活定義多種排序邏輯。 1.Comparable是類自身實現(xiàn)的接口,通過重寫compareTo()方法定義自然順序,適用於類有固定、最常用的排序方式,如String或Integer。 2.Comparator是外部定義的函數(shù)式接口,通過compare()方法實現(xiàn),適合同一類需要多種排序方式、無法修改類源碼或排序邏輯經(jīng)常變化的情況。兩者區(qū)別在於Comparable只能定義一種排序邏輯且需修改類本身,而Compar

如何在Java解析JSON? 如何在Java解析JSON? Jul 11, 2025 am 02:18 AM

解析JSON在Java中的常見方式有三種:使用Jackson、Gson或org.json。 1.Jackson適合大多數(shù)項目,性能好且功能全面,支持對象與JSON字符串之間的轉換及註解映射;2.Gson更適合Android項目或輕量級需求,使用簡單但處理複雜結構和高性能場景略遜;3.org.json適用於簡單任務或小腳本,不推薦用於大型項目,因其靈活性和類型安全不足。選擇應根據(jù)實際需求決定。

新電子郵件的Outlook快捷方式 新電子郵件的Outlook快捷方式 Jul 11, 2025 am 03:25 AM

在Outlook中快速新建郵件的方法如下:1.桌面版使用快捷鍵Ctrl Shift M,可直接彈出新郵件窗口;2.網(wǎng)頁版可通過創(chuàng)建包含JavaScript的書籤(如javascript:document.querySelector("divrole='button'").click())實現(xiàn)一鍵新建郵件;3.使用瀏覽器插件(如Vimium、CrxMouseGestures)自定義快捷鍵觸發(fā)“新建郵件”按鈕;4.Windows用戶還可通過右鍵任務欄Outlook圖標選擇“新建電

See all articles