Java Thread How to - Use Fork Join optimization








Question

We would like to know how to use Fork Join optimization.

Answer

import java.util.concurrent.ForkJoinPool;
import java.util.concurrent.RecursiveAction;
//from  ww w .  ja v  a2 s  .  c o  m
public class Main {
  static int SEQ_THRESHOLD;

  public static void main(String[] args) throws Exception {
    int size = 100000;
    int[] v1 = new int[size];
    for (int i = 0; i < size; i++) {
      v1[i] = i;
    }
    for (SEQ_THRESHOLD = 10; SEQ_THRESHOLD < size; SEQ_THRESHOLD += 50) {
      double avgTime = 0.0;
      int samples = 5;
      for (int i = 0; i < samples; i++) {
        long startTime = System.nanoTime();
        ForkJoinPool fjp = new ForkJoinPool();
        fjp.invoke(new MyAction(0, size, v1));
        long endTime = System.nanoTime();
        double secsTaken = (endTime - startTime) / 1.0e9;
        avgTime += secsTaken;
      }
      System.out.println(SEQ_THRESHOLD + " " + (avgTime / samples));
    }
  }
}

class MyAction extends RecursiveAction {
  int[] v1;
  int start, end;

  MyAction(int start, int end, int[] v1) {
    this.start = start;
    this.end = end;
    this.v1 = v1;
  }

  int SEQ_THRESHOLD = Main.SEQ_THRESHOLD;

  @Override
  protected void compute() {
    if (end - start < SEQ_THRESHOLD) {
      for (int i = start; i < end; i++) {
        v1[i] = v1[i] + i * i;
      }
    } else {
      int mid = (start + end) / 2;
      invokeAll(new MyAction(start, mid, v1), new MyAction(mid, end, v1));
    }
  }
}

The code above generates the following result.