当前位置:嗨网首页>书籍在线阅读

15-结果分析

  
选择背景色: 黄橙 洋红 淡粉 水蓝 草绿 白色 选择字体: 宋体 黑体 微软雅黑 楷体 选择字体大小: 恢复默认

结果分析

本节通过 ForkJoinPool 类和继承了 RecursiveActionTask 类,完成了一个增加数组元素的任务。而这个任务的本身也适合使用 ForkJoinPool 来实现。当任务正在处理数组时,它将输出 ForkJoinPool 的相关信息到控制台中。可以通过以下方法获取 ForkJoinPool 类的状态。

  • getPoolSize() :该方法返回当前线程池内工作线程的数量,它用 int 型变量来表示。
  • getParallelism() :该方法返回线程池的并行级。
  • getActiveThreadCount(): 该方法返回当前正在执行任务的线程数。
  • getRunningThreadCount() :该方法返回当前没有被任何同步机制阻塞的工作线程的数量。
  • getQueuedSubmissionCount() :该方法返回已经提交到线程池中但是尚未开始执行的任务数量。
  • getQueuedTaskCount() :该方法返回已经提交到线程池中并且已经开始执行的任务数量。
  • hasQueuedSubmissions(): 该方法返回一个布尔值,该值指示当前线程池中是否有正在排队却尚未执行的任务。
  • getStealCount() :该方法返回一个工作线程队列从另外一个工作线程队列中窃取的全部任务数量,它用 long 型变量表示。
  • isTerminated() :该方法返回布尔型值,它可以获知当前 fork/join 线程池是否已经完成全部任务的执行。