gpt4 book ai didi

java利用CountDownLatch实现并行计算

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 24 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章java利用CountDownLatch实现并行计算由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

本文实例为大家分享了利用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 。

最后此篇关于java利用CountDownLatch实现并行计算的文章就讲到这里了,如果你想了解更多关于java利用CountDownLatch实现并行计算的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com