java 多线程并行求和 之 join() 方法应用

24 篇文章 2 订阅
14 篇文章 0 订阅

现在 先看一个 继承Thread 类实现求和的java多线程并行程序如下:

package com.xing.add;
/**
 * 
 * @author LiuYinxing
 *
 */
public class And extends Thread{

	private long start;
	private long end;
	private long sum = 0;
	public And (long start, long end){
		super();
		this.start = start;
		this.end = end;
	}
	public void run(){
		for (long i = start; i <= end; i+=2)
			sum += i;
	}
	public long sum(){
		for (long i = start; i <= end; i++)
			sum += i;
		return sum;
	}
	public long getSum(){
		return sum;
	}
	public static void main(String[] args) throws InterruptedException{
		// TODO Auto-generated method stub
		And thread1 = new And(1, 1000000000);
		And thread2 = new And(2, 1000000000);
		long startTime = System.currentTimeMillis();
		thread1.start();
		thread2.start();
		thread1.join();
		thread2.join();
		long endTime = System.currentTimeMillis();
		System.out.println("并行结果 = " + (thread1.getSum() + thread2.getSum()));
		System.out.println("并行时间 = " + (endTime - startTime));
		
		startTime = System.currentTimeMillis();
		And serial = new And(1, 1000000000);
		long sum = serial.sum();
		endTime = System.currentTimeMillis();
		System.out.println("串行行结果 = " + sum);
		System.out.println("串行时间 = " + (endTime - startTime));
	}
}

运行结果如下:


我们可以看出线程
		thread1.start();
		thread2.start();
在调用join()方法
		thread1.join();
		thread2.join();
使其同时在多核上并行处理。由于其他的因素 加速比 700/420=1.666666667 虽然不等于2,但是并行的效果是显而易见的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值