mysql master线程 fork_多线程Fork/Join框架的使用

package com.jia.concurrency;

import java.util.ArrayList;

import java.util.concurrent.ForkJoinPool;

import java.util.concurrent.ForkJoinTask;

import java.util.concurrent.RecursiveTask;

public class CountTask extends RecursiveTask{

private static final int THRESHOLD=10000;

private long start;

private long end;

public CountTask(long start,long end) {

this.start=start;

this.end=end;

}

@Override

protected Long compute() {

long sum=0;

boolean canCompute=(end-start)

if (canCompute) {

for (long i =start; i <=end;i++) {

sum+=i;

}

}else{

//分成100个小任务

long step=(start+end)/100;

ArrayList subTasks=new ArrayList();

long pos=start;

for (int i = 0; i <100; i++) {

long lastOne=pos+step;

if (lastOne>end) {

lastOne=end;

}

CountTask subTask=new CountTask(pos, lastOne);

pos+=step+1;

subTasks.add(subTask);

subTask.fork();

}

for (CountTask countTask : subTasks) {

sum+=countTask.join();

}

}

return sum;

}

public static void main(String[] args) {

ForkJoinPool forkJoinPool=new ForkJoinPool();

CountTask task=new CountTask(0, 200000L);

ForkJoinTask result=forkJoinPool.submit(task);

try {

long res=result.get();

System.err.println("sum="+res);

} catch (Exception e) {

e.printStackTrace();

}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值