服务器之家

服务器之家 > 正文

java利用CountDownLatch实现并行计算

时间:2021-06-04 13:45     来源/作者:crz_pp

本文实例为大家分享了利用countdownlatch实现并行计算的具体代码,供大家参考,具体内容如下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
import java.util.concurrent.countdownlatch;
 
/**
 * @author pipi
 * @date 2018/10/15 13:56
 **/
public class parallelcomputing {
  private int[] nums;
  private string[] info;
  private countdownlatch countdownlatch;
 
  public parallelcomputing(string[] info) {
    this.info = info;
    int size = info.length;
    nums = new int[size];
    this.countdownlatch = new countdownlatch(size);
  }
 
  public void calc(string line, int index) throws interruptedexception {
    string[] numbers = line.split(",");
    int total = 0;
    for (string num : numbers) {
      total += integer.parseint(num);
    }
    thread.sleep(5000);
    nums[index] = total;
    countdownlatch.countdown();
    system.out.println(thread.currentthread().getname() + "执行计算任务..." + line + ",结果为:" + total);
  }
 
  public void sum() {
    system.out.println("汇总线程开始执行...");
    int total = 0;
    for (int i : nums) {
      total += i;
    }
    system.out.println("汇总线程结束执行...结果为:" + total);
  }
 
  public void calcsum() throws interruptedexception {
    int size = info.length;
    for (int i = 0; i < size; i++) {
      final int j = i;
      new thread(() -> {
        try {
          calc(info[j], j);
        } catch (interruptedexception e) {
          e.printstacktrace();
        }
      }).start();
    }
    countdownlatch.await();
    sum();
  }
 
  public static void main(string[] args) throws interruptedexception {
    long start = system.currenttimemillis();
    string[] info = {
        "2,22",
        "3,33",
        "232,32,76,84",
        "99,45,1"
    };
    parallelcomputing parallelcomputing = new parallelcomputing(info);
    parallelcomputing.calcsum();
    long end = system.currenttimemillis();
    system.out.println(end - start);
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://www.cnblogs.com/ppcoder/p/9790922.html

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
2021德云社封箱演出完整版 2021年德云社封箱演出在线看
2021德云社封箱演出完整版 2021年德云社封箱演出在线看 2021-03-15
返回顶部