欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java PriorityQueue數據結構接口原理及用法

 更新時間:2020年10月21日 09:50:31   作者:cuisuqiang  
這篇文章主要介紹了Java PriorityQueue數據結構接口原理及用法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

PriorityQueue是從JDK1.5開始提供的新的數據結構接口,它是一種基于優(yōu)先級堆的極大優(yōu)先級隊列。優(yōu)先級隊列是不同于先進先出隊列的另一種隊列。每次從隊列中取出的是具有最高優(yōu)先權的元素。如果不提供Comparator的話,優(yōu)先隊列中元素默認按自然順序排列,也就是數字默認是小的在隊列頭,字符串則按字典序排列(參閱 Comparable),也可以根據 Comparator 來指定,這取決于使用哪種構造方法。優(yōu)先級隊列不允許 null 元素。依靠自然排序的優(yōu)先級隊列還不允許插入不可比較的對象(這樣做可能導致 ClassCastException)

優(yōu)先級隊列是無界的,但是有一個內部容量,控制著用于存儲隊列元素的數組大小。它通常至少等于隊列的大小。隨著不斷向優(yōu)先級隊列添加元素,其容量會自動增加。無需指定容量增加策略的細節(jié)

簡單應用:

package test;
import java.util.PriorityQueue;
public class PriorityQueueTest1 {
 @SuppressWarnings("unchecked")
 public static void main(String[] args) {
 PriorityQueue queue = new PriorityQueue();
 queue.add("AAAAA"); // Add接受的參數是Obj,PriorityQueue使用integer String等基本的數據類型時,默認new時有參數,如果不寫則是按照默認排序
 queue.add("BBBBB"); 
 queue.add("CCCCC"); 
 queue.add("DDDDD"); 
 
 System.out.println(queue.peek()); // 獲取但不移除此隊列的頭
 System.out.println(queue.poll()); // 獲取并移除此隊列的頭
 System.out.println(queue.poll());
 
 queue.offer("ZZZZZ"); // 將指定的元素插入此優(yōu)先級隊列
 
 System.out.println(queue.poll());
 System.out.println(queue.poll());
 System.out.println(queue.poll());
 
 System.out.println(queue.poll()); // 到這里已經沒有元素,打印Null
 }
}

定義比較器:

package test;
import java.util.Comparator;
import java.util.PriorityQueue;
@SuppressWarnings("unchecked")
public class PriorityQueueTest2 {
 private static PriorityQueue queue = new PriorityQueue(10,new Comparators());
 public static void main(String[] args) {
 QueueObject queueObject = new QueueObject();
 queueObject.setId(4);
 queueObject.setObject("AAAAA");
 queue.add(queueObject);
 QueueObject queueObject1 = new QueueObject();
 queueObject1.setId(1);
 queueObject1.setObject("BBBBB");
 queue.add(queueObject1);
 QueueObject queueObject2 = new QueueObject();
 queueObject2.setId(3);
 queueObject2.setObject("CCCCC");
 queue.add(queueObject2);
 
 System.out.println(((QueueObject)queue.poll()).getObject());
 System.out.println(((QueueObject)queue.poll()).getObject());
 System.out.println(((QueueObject)queue.poll()).getObject());
 }
}
class QueueObject {
  private int id;
  private Object object;
  public int getId() {
    return id;
  }
  public void setId(int id) {
    this.id = id;
  }
  public Object getObject() {
    return object;
  }
  public void setObject(Object object) {
    this.object = object;
  }
}
@SuppressWarnings("unchecked")
class Comparators implements Comparator{
  public int compare(Object arg0, Object arg1) {
    int val1 = ((QueueObject)arg0).getId();
    int val2 = ((QueueObject)arg1).getId();
    return val1 < val2 ? 0 : 1;
  }
}

注意事項:

注意1:該隊列是用數組實現,但是數組大小可以動態(tài)增加,容量無限。

注意2:此實現不是同步的。不是線程安全的。如果多個線程中的任意線程從結構上修改了列表, 則這些線程不應同時訪問 PriorityQueue 實例,這時請使用線程安全的PriorityBlockingQueue 類。

注意3:不允許使用 null 元素。

注意4:此實現為插入方法(offer、poll、remove() 和 add 方法)提供 O(log(n)) 時間;

為 remove(Object) 和 contains(Object) 方法提供線性時間;
為檢索方法(peek、element 和 size)提供固定時間。

注意5:方法iterator()中提供的迭代器并不保證以有序的方式遍歷優(yōu)先級隊列中的元素。

至于原因可參考下面關于PriorityQueue的內部實現

如果需要按順序遍歷,請考慮使用 Arrays.sort(pq.toArray())。

注意6:可以在構造函數中指定如何排序。如:

  • PriorityQueue()
  • 使用默認的初始容量(11)創(chuàng)建一個 PriorityQueue,并根據其自然順序來排序其元素(使用 Comparable)。
  • PriorityQueue(int initialCapacity)
  • 使用指定的初始容量創(chuàng)建一個 PriorityQueue,并根據其自然順序來排序其元素(使用 Comparable)。
  • PriorityQueue(int initialCapacity, Comparator comparator)
  • 使用指定的初始容量創(chuàng)建一個 PriorityQueue,并根據指定的比較器comparator來排序其元素。

注意7:此類及其迭代器實現了 Collection 和 Iterator 接口的所有可選 方法。

PriorityQueue的內部實現

PriorityQueue對元素采用的是堆排序,頭是按指定排序方式的最小元素。堆排序只能保證根是最大(最小),整個堆并不是有序的。

方法iterator()中提供的迭代器可能只是對整個數組的依次遍歷。也就只能保證數組的第一個元素是最小的

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 基于maven使用IDEA創(chuàng)建多模塊項目

    基于maven使用IDEA創(chuàng)建多模塊項目

    這篇文章主要介紹了基于maven使用IDEA創(chuàng)建多模塊項目,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • 詳解記錄Java Log的幾種方式

    詳解記錄Java Log的幾種方式

    很多小伙伴不知道如何記錄日志,今天特地整理了本篇文章,文中有非常詳細的介紹及代碼示例,對小伙伴們很有幫助,需要的朋友可以參考下
    2021-06-06
  • JPA如何使用findBy方法自定義查詢

    JPA如何使用findBy方法自定義查詢

    這篇文章主要介紹了JPA如何使用findBy方法自定義查詢,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Java深度復制功能與用法實例分析

    Java深度復制功能與用法實例分析

    這篇文章主要介紹了Java深度復制功能與用法,簡單講述了深度復制的概念、功能并結合實例形式分析了java實現深度復制的具體操作技巧,需要的朋友可以參考下
    2018-01-01
  • spring?security需求分析與基礎環(huán)境準備教程

    spring?security需求分析與基礎環(huán)境準備教程

    這篇文章主要為大家介紹了spring?security需求分析與基礎環(huán)境準備教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2022-03-03
  • Java調取創(chuàng)藍253短信驗證碼的實現代碼

    Java調取創(chuàng)藍253短信驗證碼的實現代碼

    這篇文章主要介紹了Java調取創(chuàng)藍253短信驗證碼的實現代碼,需要的朋友可以參考下
    2018-04-04
  • springboot+HttpInvoke?實現RPC調用的方法

    springboot+HttpInvoke?實現RPC調用的方法

    RPC框架大家或多或少都用過,出自于阿里系的就有dubbo,HSF,sofaRPC等,今天通過本文給大家介紹springboot+HttpInvoke?實現RPC調用的方法,感興趣的朋友一起看看吧
    2022-03-03
  • 一篇文章弄懂JVM類加載機制過程以及原理

    一篇文章弄懂JVM類加載機制過程以及原理

    JVM原理對于初學者而言,比較晦澀難以理解,概念繁多又比較抽象,很多時候感覺看不見摸不著,還不好驗證,下面這篇文章主要給大家介紹了關于如何通過一篇文章弄懂JVM類加載機制過程及原理的相關資料,需要的朋友可以參考下
    2023-02-02
  • java遍歷Map的幾種方法分析

    java遍歷Map的幾種方法分析

    這篇文章主要介紹了java遍歷Map的幾種方法,結合實例形式分析了使用循環(huán)與迭代等方法操作Map遍歷的相關技巧,需要的朋友可以參考下
    2016-08-08
  • 搭建MyBatis-Plus框架并進行數據庫增刪改查功能

    搭建MyBatis-Plus框架并進行數據庫增刪改查功能

    這篇文章主要介紹了搭建MyBatis-Plus框架并進行數據庫增刪改查,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03

最新評論