zoukankan      html  css  js  c++  java
  • ForkJoin

    package example.test;
    
    import java.util.ArrayList;
    import java.util.Arrays;
    import java.util.List;
    import java.util.Random;
    import java.util.concurrent.ForkJoinPool;
    import java.util.concurrent.ForkJoinTask;
    import java.util.concurrent.RecursiveTask;
    
    public class TSKK {
    
    	public static void main(String[] args) throws Exception {
    		// 创建随机数组成的数组:
    		Long[] array = new Long[40000000];
    		fillRandom(array);
    
    		test01(array);
    		test02(array);
    	}
    
    	public static void test01(Long[] array) {
    		// fork/join task:
    		ForkJoinPool fjp = new ForkJoinPool(4); // 最大并发数4
    		ForkJoinTask<Long> task = new SumTask(array, 0, array.length);
    		long startTime = System.currentTimeMillis();
    		Long result = fjp.invoke(task);
    		long endTime = System.currentTimeMillis();
    		System.out.println("Fork/join sum: " + result + " in " + (endTime - startTime) + " ms.");
    
    	}
    
    	public static void test02(Long[] array) {
    		List<Long> arrays = new ArrayList<>(Arrays.asList(array));
    		long startTime = System.currentTimeMillis();
    		Long result = arrays.stream().parallel().reduce(0L, Long::sum);
    		long endTime = System.currentTimeMillis();
    		System.out.println("stream/join sum: " + result + " in " + (endTime - startTime) + " ms.");
    	}
    
    	public static void fillRandom(Long[] array) {
    		Random random = new Random();
    		for (int i = 0; i < array.length; i++) {
    			array[i] = random.nextLong();
    		}
    	}
    }
    
    @SuppressWarnings("serial")
    class SumTask extends RecursiveTask<Long> {
    
    	static final int THRESHOLD = 100000;
    	Long[] array;
    	int start;
    	int end;
    
    	SumTask(Long[] array, int start, int end) {
    		this.array = array;
    		this.start = start;
    		this.end = end;
    	}
    
    	@Override
    	protected Long compute() {
    		if (end - start <= THRESHOLD) {
    			// 如果任务足够小,直接计算:
    			long sum = 0;
    			for (int i = start; i < end; i++) {
    				sum += array[i];
    			}
    			// System.out.println(String.format("compute %d~%d = %d", start, end, sum));
    			return sum;
    		}
    		// 任务太大,一分为二:
    		int middle = (end + start) / 2;
    		// System.out.println(String.format("split %d~%d ==> %d~%d, %d~%d", start, end,
    		// start, middle, middle, end));
    		SumTask subtask1 = new SumTask(this.array, start, middle);
    		SumTask subtask2 = new SumTask(this.array, middle, end);
    		invokeAll(subtask1, subtask2);
    		Long subresult1 = subtask1.join();
    		Long subresult2 = subtask2.join();
    		Long result = subresult1 + subresult2;
    		// System.out.println("result = " + subresult1 + " + " + subresult2 + " ==> " +
    		// result);
    		return result;
    	}
    }
    

      

  • 相关阅读:
    Mybatis数据库操作的返回值
    Java中设置classpath、path、JAVA_HOME的作用?
    mysql备份与还原,增量备份;使用ibd和frm文件恢复数据
    SQLAlchemy会话与事务控制:互斥锁和共享锁
    log4j设置,以及中文乱码,通过过滤器输出指定级别的日志,或者指定级别范围的日志
    SQL重复记录查询-count与group by having结合查询重复记录
    css样式美化 下拉框 select 样式
    人人都是 DBA(XIII)索引信息收集脚本汇编
    java线程安全问题之静态变量、实例变量、局部变量
    java uuid第一次性能
  • 原文地址:https://www.cnblogs.com/jpit/p/8267321.html
Copyright © 2011-2022 走看看