/**
* @author 万星明
* @version 创建时间:2018年10月18日 下午6:41:41
* 计算任务,一个包含了2千个整数的数组,分拆了多个线程来进行并行计算,最后汇总出计算的结果。
*/
//创建一个ArraySum的类,继承Thread使得其为线程类
public class ArraySum extends Thread{
//属性data(数组数据)、startNum(每个线程开始读取的下标)、endNum(读取结束的下标)
//sum(每个线程的和)、allSum(所有线程的和
private int[] data;
private int startNum;
private int endNum;
public static int sum;
public static int allSum;
//构造方法,传入数组数据data,线程读取下标startNum,线程读取结束下标endNum
public ArraySum(int[] data, int startNum, int endNum) {
super();
this.data = data;
this.startNum = startNum;
this.endNum = endNum;
}
//线程主要运行的方法
public void run() {
int sum = 0;
//线程从开始下标加到结束下标
for (int i = startNum; i<endNum; i++) {
sum += data[i];
}
System.out.println("线程"+Thread.currentThread().getName()+"和:"+sum);
//将线程的sum加到allSum
allSum += sum;
}
}
java多个线程来进行并行计算包含了2千个整数的数组和
最新推荐文章于 2021-02-27 03:36:11 发布