`

Fork/Join框架

 
阅读更多

           Doug Lea教授写了一个并行处理的框架,最近偶然看见他的论文。拜读了一下感觉很好。这个框架佳作Fork/Join框架,顾名思义就是先进行fork再join组合结果的意思。下面是这篇论文的地址,英文好的同志可以好好看一下:http://gee.cs.oswego.edu/dl/papers/fj.pdf

           如果觉得英文论文有点难懂,我按照我自己的理解写在下面帮助大家理解一下:

      首先,关于Fork/Join的大篇幅的介绍就不在这里写了,大家可以百度了解一下。我主要介绍一下用法。

      分治的思想在我们计算机圈是很有名的,分治分治,分而治之。这个Fork/Join有点并行分治的意思。

      要想使用这个框架必须继承RecursiveTask<T>或者RecursiveAction<T>,我从两个例子解释一下这两个的不同。

 

问题1:高斯定理可以很快的计算等差序列的加法,我们就用Fork/Join框架实现一下等差序列的加法:

 

package com.wjy.enumstudy;

import java.util.concurrent.ExecutionException;
import java.util.concurrent.ForkJoinPool;
import java.util.concurrent.Future;
import java.util.concurrent.RecursiveTask;

public  class PlusPlus extends RecursiveTask<Integer>{
	private static final int THRESHOLE=100;
	private int start;
	private int end;
	public PlusPlus(int start,int end){
		this.start=start;
		this.end=end;
	}
	
	@Override
	protected Integer compute() {
		// TODO Auto-generated method stub
		int sum=0;
		if(end-start<THRESHOLE){
			for(int i=start;i<=end;i++){
				sum+=i;
			}
		}else{
			int middle=(start+end)/2;
			PlusPlus left=new PlusPlus(start, middle);
			PlusPlus right=new PlusPlus(middle+1, end);
			
			left.fork();
			right.fork();
			sum=left.join()+right.join();
		}
		return sum;
	}
	
	public static void main(String args[]) throws InterruptedException, ExecutionException{
		ForkJoinPool pool=new ForkJoinPool();
		Future<Integer> result=pool.submit(new PlusPlus(1, 10000));
		System.out.println(result.get());
		System.err.println(10001*5000);
	}
	
}

 算法很简单,在100个数以内的我们直接迭代计算和值。否则采用Fork/Join框架分治计算。

 

注:System.err.println(10001*5000);是高斯定理计算的答案。做对比用。

运行结果:

 

50005000

50005000

 

通过上面的例子可以看出来RecursiveTask是有返回值的。而RecursiveAction是没有的,比如说排序就不需要有返回值。所以第二个例子就是排序,使用RecursiveAction。

 

问题2:给数组排序:

package com.wjy.enumstudy;

import java.util.Arrays;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ForkJoinPool;
import java.util.concurrent.Future;
import java.util.concurrent.RecursiveAction;
import java.util.concurrent.RecursiveTask;
import java.util.concurrent.TimeUnit;

public  class SortSort extends RecursiveAction{
	private static final int THRESHOLE=10;
	private int[] array;
	private int start;
	private int end;
	public SortSort(int[] array,int start,int end){
		this.array=array;
		this.start=start;
		this.end=end;
	}
	private void sampleSort(int[] array,int start,int end){
		Arrays.sort(array, start, end+1);  //看这里toIndex是end+1!!!
	}
	private void swap(int[] array,int numA,int numB){
		array[numA]=array[numA]+array[numB];
		array[numB]=array[numA]-array[numB];
		array[numA]=array[numA]-array[numB];
	}
	/**
	 * 像快排一样每次保证最后一个数处在最终的正确位置上
	 * 比他小的在他左边,比他大的在他右边
	 * @param array
	 * @param start
	 * @param end
	 * @return
	 */
	private int partion(int[] array,int start,int end){
		int small=start;
		int count=0;
		int value=array[end];
		int length=end-start+1;
		for(int i=start;i<end;i++){
			if(array[i]<value){
				if(i!=small)
				{
					swap(array, i, small);
				}
				small++;
				count++;
			}
		}
		if((start+count)!=end){
			swap(array, start+count, end);
		}
		
		return start+count;
	}
	@Override
	protected void compute() {
		// TODO Auto-generated method stub
		if(end-start<THRESHOLE){
			sampleSort(array,start,end);
		}else{
			int tag=partion(array,start,end);
			new SortSort(array, start, tag-1).fork();
			new SortSort(array, tag+1, end).fork();
		}
	}
	
	
	public static void main(String args[]) throws InterruptedException, ExecutionException{
		int array[]={3,7,2,1,5,4,3,8,9,4,6};
		ForkJoinPool pool=new ForkJoinPool();
		pool.submit(new SortSort(array,0,array.length-1));
		pool.shutdown();
		pool.awaitTermination(1000, TimeUnit.SECONDS);
		
		System.out.println(Arrays.toString(array));
	}



}

 运行结果:

[1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9]

 

对于Arrays.sort(array,fromIndex,toIndex);这个函数,其中的toIndex要给的比预想的大一。举个例子:

对于int[] array={3,2,1};

要是Arrays.sort(array,0,2);的话运行结果是{2,3,1}。

所以必须是Arrays.sort(array,0,3);

 

 

 

分享到:
评论

相关推荐

    java Fork Join框架及使用

    Fork/Join框架是Java7引入的一种用于并行任务执行的框架,它允许将复杂任务拆分成多个子任务,并行执行,然后通过join操作将结果聚合。Fork/Join框架特别适合处理可以递归拆分的计算密集型任务,比如大数据集的搜索...

    Fork/Join框架Package jsr166y

    Fork/Join框架Package jsr166y是Java 7并行编程类的的初步版本(Preliminary versions of classes targeted for Java 7.)

    Fork/Join例子

    在Java编程领域,Fork/Join框架是一种并行计算模型,设计用于高效处理大量数据,尤其是在多核处理器系统上。这个框架是Java 7引入的一个重要特性,它基于分而治之(Divide and Conquer)策略,将复杂任务拆分为更小...

    fork/join 实例

    Fork/Join框架是Java并发处理的一个重要工具,它基于工作窃取算法,设计用于高效地执行并行计算任务。这个框架是Java 7引入的,位于`java.util.concurrent.fork/join`包中,目的是简化多核处理器环境下大规模数据...

    Java中的Fork/Join框架

     fork/join框架是ExecutorService接口的一个实现,可以帮助开发人员充分利用多核处理器的优势,编写出并行执行的程序,提高应用程序的性能;设计的目的是为了处理那些可以被递归拆分的任务。  fork/join框架与...

    Java中的Fork,Join框架深度解析

    Java的Fork/Join框架是一种用于并行计算的框架,它基于分治法的原理,将大任务分解成小任务并行执行,最后再将结果合并。这种框架特别适合于可以分解为多个子任务且子任务可以并行处理的场景。本文将详细介绍Fork/...

    java NIO用法及java fork/join 用法源码工程

    结合这两个技术,你可以创建高效的并发服务器,比如一个服务器端使用NIO监听和处理来自多个客户端的连接,而每个客户端请求的处理则可以利用Fork/Join框架进行并行计算。在实际项目中,`nioSample`工程可能包含这些...

    Java并发Fork and join

    Fork/Join框架是Java并发库中的一部分,自Java 7开始引入,它为开发者提供了一种高效的处理大规模计算任务的方法。这个框架基于分治策略,将大任务分解成若干小任务,然后并行执行这些小任务,最后再将结果合并。...

    Java Fork/Join框架

    Java Fork/Join框架是Java 7引入的一种并行计算模型,设计目的是为了高效地处理大量数据,尤其是在多核处理器环境中。该框架的核心理念是通过将复杂的大任务分解为多个小任务,然后并行执行这些小任务,从而加速计算...

    Fork Join框架机制详解.docx

    Fork/Join框架基于分治策略,即将一个复杂的大任务分解成两个或更多个较小的任务,直到这些任务小到可以直接计算结果,然后将这些结果合并得到最终答案。在Java中,Fork/Join框架主要由`ForkJoinPool`线程池和`...

    Fork-Join框架演示

    ### Java Fork-Join框架详解与应用 #### 一、并发编程与Fork-Join框架的引入 在现代计算环境中,多核处理器已经成为标配,这为软件开发者提供了利用硬件并行性的巨大潜力。然而,传统的并发编程模型,如基于线程的...

    35 拆分你的任务—学习使用Fork-Join框架.pdf

    在Java并发编程中,Fork/Join框架是一个强大的工具,尤其在处理大量数据时能显著提升性能。这个框架从Java 7开始引入,是ExecutorService的一个实现,它基于分而治之的策略,将大任务分解成多个小任务,然后并行地...

    译文:Fork and Join: Java Can Excel at Painless Parallel Programming Too!

    Fork/Join框架是Java SE 7引入的一项重要技术,它使得编写高效、并行的程序变得更加容易。本文将简要回顾Java中的并发编程基础知识,介绍java.util.concurrent包提供的高级并发原语,并深入探讨Fork/Join框架及其在...

    浅谈Java Fork/Join并行框架

    Java Fork/Join 并行框架 Java Fork/Join 并行框架是 Java 7 中引入的一个并行任务框架,可以将任务分割成足够小的小任务,然后让不同的线程来做这些分割出来的小事情,然后完成之后再进行 join,将小任务的结果...

    ForkJoinUtil.java,一个分而治之的框架工具类

    Fork/Join框架的测试demo,含源代码。 Fork/Join框架是Java7提供了的一个用于并行执行任务的框架, 是一个把大任务分割成若干个小任务,最终汇总每个小任务结果后得到大任务结果的框架。 我们再通过Fork和Join这两个...

    Fork:join框架与CompleteableFuture源码解析.pptx

    全网第一篇通过图文介绍Fork/Join框架与CompleteableFuture的PPT

    Java通过Fork/Join优化并行计算

    Java的Fork/Join框架是Java 7引入的一个并行计算工具,它是基于分而治之(Divide and Conquer)策略的。该框架旨在简化并行编程,尤其是在多核处理器环境中提高性能。Fork/Join框架的核心类包括`ForkJoinPool`和`...

    java fork-join框架介绍

    fork/join框架是ExecutorService接口的一个实现,可以帮助开发人员充分利用多核处理器的优势,编写出并行执行的程序,提高应用程序的性能;设计的目的是为了处理那些可以被递归拆分的任务。

    实验报告二+15130130273+石明皓1

    在本实验报告中,主题是Java并行程序设计,主要涉及了使用Fork/Join框架进行多线程并行计算。Fork/Join框架是Java并发处理的一种高效工具,尤其适用于那些可以分解成子问题的问题。以下是实验的具体知识点: 1. **...

Global site tag (gtag.js) - Google Analytics