当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Java PriorityBlockingQueue comparator()用法及代码示例


PriorityBlockingQueue的comparator()方法返回比较器,该比较器可用于对PriorityBlockingQueue中的元素进行排序。如果队列遵循元素的自然排序模式,则该方法返回null值。

用法:

public Comparator<? super E> comparator()

返回值:此方法返回用于以特定顺序对集合中的元素进行排序的比较器集合。如果PriorityBlockingQueue遵循默认或自然排序模式,则它将返回null值。


下面的程序说明PriorityBlockingQueue的comparator()方法:

示例1:演示PriorityBlockingQueue上的comparator()方法,该方法包含整数列表。

// Java Program Demonstrate comparator() 
// method of PriorityBlockingQueue 
  
import java.util.concurrent.PriorityBlockingQueue; 
import java.util.*; 
  
public class GFG { 
    public static void main(String[] args) 
        throws InterruptedException 
    { 
  
        // create object of PriorityBlockingQueue 
        PriorityBlockingQueue<Integer> PrioQueue 
            = new PriorityBlockingQueue<Integer>(); 
  
        // Add numbers to PriorityBlockingQueue 
        PrioQueue.put(45815616); 
        PrioQueue.put(4981561); 
        PrioQueue.put(4594591); 
        PrioQueue.put(9459156); 
  
        // get String representation of PriorityBlockingQueue 
        String str = PrioQueue.toString(); 
  
        // Creating a comparator using comparator() 
        Comparator comp = PrioQueue.comparator(); 
  
        // Displaying the comparator values 
        System.out.println("Comparator value: " + comp); 
  
        if (comp == null) 
            System.out.println("PriorityBlockingQueue"
                               + "follows natural ordering"); 
        else
            System.out.println("PriorityBlockingQueue follows"
                               + comp); 
    } 
}
输出:
Comparator value: null
PriorityBlockingQueuefollows natural ordering

示例2:演示PriorityBlockingQueue上的toString()方法,该方法包含字符串列表。

// Java Program Demonstrate comparator() 
// method of PriorityBlockingQueue 
  
import java.util.concurrent.PriorityBlockingQueue; 
import java.util.*; 
  
// Comparator to compare Strings 
class COMPARING implements Comparator<String> { 
    public int compare(String str1, String str2) 
    { 
        return str2.compareTo(str1); 
    } 
} 
  
public class GFG { 
    public static void main(String[] args) 
        throws InterruptedException 
    { 
  
        // define capacity of PriorityBlockingQueue 
        int capacityOfQueue = 5; 
  
        // create object of PriorityBlockingQueue 
        // by passing capacity and comparator class 
        // as parameters. 
        PriorityBlockingQueue<String> characters 
            = new PriorityBlockingQueue<String>(capacityOfQueue, 
                                                new COMPARING()); 
  
        // Add Strings 
        characters.add("Geeks"); 
        characters.add("forGeeks"); 
        characters.add("A computer portal"); 
  
        // Getting the comparator using comparator() 
        Comparator comp = characters.comparator(); 
  
        // Displaying the comparator values 
        System.out.println("Comparator value is: " + comp); 
  
        if (comp == null) 
            System.out.println("PriorityBlockingQueue"
                               + "follows natural ordering"); 
        else
            System.out.println("PriorityBlockingQueue follows: "
                               + comp); 
        // display result 
        System.out.println("\nThe elements after custom Comparator"); 
        for (String e : characters) 
            System.out.print(e + ", "); 
    } 
}
输出:
Comparator value is: COMPARING@28d93b30
PriorityBlockingQueue follows: COMPARING@28d93b30

The elements after custom Comparator
forGeeks, Geeks, A computer portal,

注:本文由纯净天空筛选整理自 PriorityBlockingQueue comparator() method in Java。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。