日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
JavaForkJoin框架的原理及用法

這篇文章主要介紹了Java ForkJoin框架的原理及用法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

專注于為中小企業(yè)提供成都網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)、外貿(mào)營(yíng)銷網(wǎng)站建設(shè)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)江寧免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了近1000家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

ForkJoin分析

一、ForkJoin

ForkJoin是由JDK1.7后提供多線并發(fā)處理框架。ForkJoin的框架的基本思想是分而治之。什么是分而治之?分而治之就是將一個(gè)復(fù)雜的計(jì)算,按照設(shè)定的閾值進(jìn)行分解成多個(gè)計(jì)算,然后將各個(gè)計(jì)算結(jié)果進(jìn)行匯總。相應(yīng)的ForkJoin將復(fù)雜的計(jì)算當(dāng)做一個(gè)任務(wù)。而分解的多個(gè)計(jì)算則是當(dāng)做一個(gè)子任務(wù)。

Java ForkJoin框架的原理及用法

二、ForkJoin的使用

下面我們以計(jì)算一個(gè)長(zhǎng)度為一個(gè)億的隨機(jī)數(shù)整數(shù)數(shù)組為例來(lái)展示一下ForkJoin的使用:

1.創(chuàng)建Task

​ 使用ForkJoin框架,需要?jiǎng)?chuàng)建一個(gè)ForkJoin的任務(wù),而ForkJoinTask是一個(gè)抽象類,我們不需要去繼承ForkJoinTask進(jìn)行使用。因?yàn)镕orkJoin框架為我們提供了RecursiveAction和RecursiveTask(子任務(wù)有返回值)。我們只需要繼承ForkJoin為我們提供的抽象類的其中一個(gè)并且實(shí)現(xiàn)compute方法。

private static class SumTask extends RecursiveTask{

  //設(shè)定計(jì)算長(zhǎng)度的閾值為總長(zhǎng)度的十分之一也就是一千萬(wàn)
  private final static int THRESHOLD = MakeArray.ARRAY_LENGTH/10;
  private int[] src; //表示我們要實(shí)際統(tǒng)計(jì)的數(shù)組
  private int fromIndex;//開(kāi)始統(tǒng)計(jì)的下標(biāo)
  private int toIndex;//統(tǒng)計(jì)到哪里結(jié)束的下標(biāo)

  public SumTask(int[] src, int fromIndex, int toIndex) {
    this.src = src;
    this.fromIndex = fromIndex;
    this.toIndex = toIndex;
  }

  @Override
  protected Integer compute() {
    //計(jì)算長(zhǎng)度如果小于設(shè)定長(zhǎng)度就不需要分解任務(wù)
    if(toIndex-fromIndex < THRESHOLD) {
      int count = 0;
      for(int i=fromIndex;i<=toIndex;i++) {
        count = count + src[i];
      }
      return count;
    }else {
      int mid = (fromIndex+toIndex)/2;
      SumTask left = new SumTask(src,fromIndex,mid);
      SumTask right = new SumTask(src,mid+1,toIndex);
      //將任務(wù)進(jìn)行拆分
      invokeAll(left,right);
      //連接返回結(jié)果
      return left.join()+right.join();
    }
  }
}

2.使用ForkJoinPool進(jìn)行執(zhí)行

​ task要通過(guò)ForkJoinPool來(lái)執(zhí)行,分割的子任務(wù)也會(huì)添加到當(dāng)前工作線程的雙端隊(duì)列中,進(jìn)入隊(duì)列的頭部。當(dāng)一個(gè)工作線程中沒(méi)有任務(wù)時(shí),會(huì)從其他工作線程的隊(duì)列尾部獲取一個(gè)任務(wù)(工作竊取)。

public static void main(String[] args) {
  ForkJoinPool pool = new ForkJoinPool();
  int[] src = MakeArray.makeArray();
  SumTask innerFind = new SumTask(src,0,src.length-1);
  long start = System.currentTimeMillis();
  pool.invoke(innerFind);//同步調(diào)用
}

三、ForkJoin注意點(diǎn)

  • 使用ForkJoin將相同的計(jì)算任務(wù)通過(guò)多線程的進(jìn)行執(zhí)行。從而能提高數(shù)據(jù)的計(jì)算速度。在google的中的大數(shù)據(jù)處理框架mapreduce就通過(guò)類似ForkJoin的思想。通過(guò)多線程提高大數(shù)據(jù)的處理。但是我們需要注意:
  • 使用這種多線程帶來(lái)的數(shù)據(jù)共享問(wèn)題,在處理結(jié)果的合并的時(shí)候如果涉及到數(shù)據(jù)共享的問(wèn)題,我們盡可能使用JDK為我們提供的并發(fā)容器。
  • ForkJoin也是通過(guò)多線程的方式進(jìn)行處理任務(wù)。那么我們不得不考慮是否應(yīng)該使用ForkJoin。因?yàn)楫?dāng)數(shù)據(jù)量不是特別大的時(shí)候,我們沒(méi)有必要使用ForkJoin。因?yàn)槎嗑€程會(huì)涉及到上下文的切換。所以數(shù)據(jù)量不大的時(shí)候使用串行比使用多線程快。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


分享標(biāo)題:JavaForkJoin框架的原理及用法
瀏覽路徑:http://www.dlmjj.cn/article/ipeocc.html