zoukankan      html  css  js  c++  java
  • 线程池的工作队列

    1、线程池的几种工作队列?

    • ArrayBlockingQueue
    • LinkedBlockingQueue
    • DelayQueue
    • PriorityBlockingQueue
    • SynchronousQueue

    (1)ArrayBlockingQueue

    ArrayBlockingQueue(有界队列)是一个用数组实现的有界阻塞队列,按FIFO排序量。

    (2)LinkedBlockingQueue

    LinkedBlockingQueue(可设置容量队列)基于链表结构的阻塞队列,按FIFO排序任务,容量可以选择进行设置,不设置的话,将是一个无边界的阻塞队列,最大长度为Integer.MAX_VALUE,吞吐量通常要高于ArrayBlockingQuene;

    newFixedThreadPool线程池使用了这个队列。

    (3)DelayQueue

    DelayQueue(延迟队列)是一个任务定时周期的延迟执行的队列。根据指定的执行时间从小到大排序,否则根据插入到队列的先后排序。

    newScheduledThreadPool线程池使用了这个队列。

    (4)PriorityBlockingQueue

    PriorityBlockingQueue(优先级队列)是具有优先级的无界阻塞队列;

    (5)SynchronousQueue

    SynchronousQueue(同步队列)一个不存储元素的阻塞队列,每个插入操作必须等到另一个线程调用移除操作,否则插入操作一直处于阻塞状态,吞吐量通常要高于LinkedBlockingQuene

    newCachedThreadPool线程池使用了这个队列。

    说出它们的特点,并结合使用到对应队列的常用线程池(如newFixedThreadPool线程池使用LinkedBlockingQueue),进行展开阐述。

    补充:java并发包

    •   ArrayBlockingQueue:一个由数组结构组成的有界阻塞队列。 
    •   LinkedBlockingQueue:一个由链表结构组成的有界阻塞队列。 
    •   PriorityBlockingQueue:一个支持优先级排序的无界阻塞队列。 
    •   DealyQueue:一个使用优先级队列实现的无界阻塞队列。 
    •   SynchronousQueue:一个不存储元素的阻塞队列。 
    •   LinkedTransferQueue:一个由链表结构组成的无界阻塞队列。 
    •   LinkedBlockingDeque:一个由链表结构组成的双向阻塞队列。
  • 相关阅读:
    运行.bat批处理,CMD窗口隐藏,并制作为EXE文件
    TinyXML:一个优秀的C++ XML解析器(转载)
    2013编程之美资格赛【传话游戏】
    linux GTK教程(消息机制/标签/按钮/图像/文本/对话框/菜单/容器)
    c++强制类型转换(总结)
    string与char*的转换(转载)
    网络数据包捕获函数库Libpcap安装与使用(非常强大)
    Linux 高级Socket编程
    linux GTK 安装
    .dll和.lib文件的生成和使用 c++
  • 原文地址:https://www.cnblogs.com/guoyu1/p/13573328.html
Copyright © 2011-2022 走看看