Java线程池ForkJoinPool实例解析
这篇文章主要介绍了Java线程池ForkJoinPool实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
背景:ForkJoinPool的优势在于,可以充分利用多cpu,多核cpu的优势,把一个任务拆分成多个“小任务”,把多个“小任务”放到多个处理器核心上并行执行;当多个“小任务”执行完成之后,再将这些执行结果合并起来即可。这种思想值得学习。
importjava.io.IOException;
importjava.util.Arrays;
importjava.util.Random;
importjava.util.concurrent.RecursiveAction;
importjava.util.concurrent.RecursiveTask;
/**
*分割合并线程池
*类似于递归的归并排序,这个是多线程的递归排序
*jdk1.7之后加的
*/
publicclassForkJoinPool{
staticint[]nums=newint[1000000];
staticfinalintMAX_NUM=50000;
staticRandomrandom=newRandom();
static{
for(inti=0;i{
intstart,end;
publicAddTask(intstart,intend){
this.start=start;
this.end=end;
}
@Override
protectedLongcompute(){
if(end-start<=MAX_NUM){
longsum=0L;
for(inti=start;i
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。