java~优先级队列PriorityQueue

概念

PriorityQueue是一种支持排序的优先级队列,你入队列的对象需要实现Comparable或Comparator接口,或者它本身支持自然排序,如Integer,Long这些类型(这些类型也都实现了Comparable接口)。

数据结构

优先级队列底层的数据结构其实是一颗二叉堆,什么是二叉堆呢?我们来看看下面的图(a为大顶堆,b为小顶堆)
[图片上传失败...(image-42c37-1651027691863)]

  • 在这里我们会发现以下特征:
  1. 二叉堆是一个完全二叉树
  2. 根节点总是大于左右子节点(大顶堆),或者是小于左右子节点(小顶堆)。

java代码例子

  • 定义一个对象,实现Comparable接口
@Data
  static class Customer implements Comparable<Customer> {
    private int id;
    private String name;

    public Customer(int i, String n) {
      this.id = i;
      this.name = n;
    }

    public int getId() {
      return id;
    }

    public String getName() {
      return name;
    }

    @Override
    public int compareTo(Customer o) {
      if (this.id < o.id) return -1; // 小于目标值,返回-1表示升序,即-1表示数值由小到大的排序
      else if (this.id == o.id) return 0;
      else return 1;
    }
  }

  • 添加测试用例
  @Test
  public void test() {
    Queue<Customer> priorityQueue = new PriorityQueue<>();
    priorityQueue.add(new Customer(1, "zhansan"));
    priorityQueue.add(new Customer(2, "lisi"));
    priorityQueue.add(new Customer(4, "wangwu"));
    while (!priorityQueue.isEmpty()) {
      Customer cust = priorityQueue.poll();
      System.out.println("Processing Customer =" + cust.toString());
    }
  }

  • 测试结果,按着id的升序出队列
Processing Customer =PriorityQueueTest.Customer(id=1, name=zhansan)
Processing Customer =PriorityQueueTest.Customer(id=2, name=lisi)
Processing Customer =PriorityQueueTest.Customer(id=4, name=wangwu)

在此我向大家推荐一个架构学习交流圈。交流学习微信:539413949(里面有大量的面试题及答案)里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化、分布式架构等这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多


版权声明:本文为m0_68064743原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。