ArrayBlockingQueue
底层维护了一个定长的数组,在生产者生产数据和消费者消费消费数据,共用同一个锁对象。
LinkedBlockingQueue
底层维护了一个链表,当生产者线程往队列中生产数据时,消费者线程同时消费队列中的数据,
原因就是生产者和消费者采用了额独立的锁来控制数据的同步。
关于ArrayBlockingQueue和LinkedBlockingQueue的异同,请移步我的另一篇博客:https://blog.csdn.net/weixin_43729854/article/details/107882990
SynchrousQueue
天然实现了生产者和消费者,只作为中转者。
DelayQueue
其中的元素只有当指定的延迟时间到了,才能够从队列中获取元素。
PriorityBlockingQueue
基于优先级的阻塞队列,优先级的判断需要通过构造函数传入的Compartor对象决定,
注意的是其不会阻塞生产者线程,而只会在没有数据可消费时,阻塞消费者线程。
核心方法
- offer(obj) 返回true/false
- offer(obj, timeout) 可以设定等待的时间,如果在指定的时间内,不能添加则会返回失败
- put(obj) 阻塞方法
- poll(time) 到达time仍然获取不到返回null
- poll(timeout, unit) 如果在指定时间内,队列一旦有数据则立即返回,反之时间超时还没有数据,则返回失败
- take() 阻塞方法