Java1.6多线程之同步方法

package com.starit.open.main;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

/**
 * 
 * @author wenin819
 * 
 *         Callable 和 Future接口
 *         Callable是类似于Runnable的接口,实现Callable接口的类和实现Runnable的类都是可被其它线程执行的任务。
 *         Callable和Runnable有几点不同: 
 *         (1)Callable规定的方法是call(),而Runnable规定的方法是run().
 *         (2)Callable的任务执行后可返回值,而Runnable的任务是不能返回值的。
 *         (3)call()方法可抛出异常,而run()方法是不能抛出异常的。 
 *         (4)运行Callable任务可拿到一个Future对象,
 *         Future 表示异步计算的结果。它提供了检查计算是否完成的方法,以等待计算的完成,并检索计算的结果。
 *         通过Future对象可了解任务执行情况,可取消任务的执行,还可获取任务执行的结果。
 * 
 */
public class CallableThreadSync implements Runnable{
	
	private static final ExecutorService es = Executors.newFixedThreadPool(5);
	
	public static class ItemThread implements Callable<Integer> {
		public int addNum;
		public ItemThread(int addNum) {
			this.addNum = addNum;
		}
		
		@Override
		public Integer call() {
			try {
				Thread.sleep(addNum * 1000);
			} catch (InterruptedException e) {
				e.printStackTrace();
			}
			return addNum * 2;
		}
	}
	
	public static void main(String[] args) {
		CallableThreadSync test = new CallableThreadSync();
		long startTime = System.currentTimeMillis();
		new Thread(test, "thread1").start();
		new Thread(test, "thread2").start();
		long endTime = System.currentTimeMillis();
		System.out.println("main:用时" + (endTime - startTime) / 1000 + "秒");
	}

	public void run() {
		long startTime = System.currentTimeMillis();
		List<ItemThread> itemThreads = new ArrayList<CallableThreadSync.ItemThread>(3);
		ItemThread itemThread = null;
		for(int i = 0; i < 3; i++) {
			itemThread = new ItemThread(i + 1);
			itemThreads.add(itemThread);
		}
		List<Future<Integer>> futureList = null;
		try {
			futureList = es.invokeAll(itemThreads);
		} catch (InterruptedException e1) {
			e1.printStackTrace();
		}
		Integer result = 1;
		for(Future<Integer> future : futureList) {
				try {
					result += future.get();
				} catch (InterruptedException e) {
					e.printStackTrace();
				} catch (ExecutionException e) {
					e.printStackTrace();
				}
		}
		String infoMsg = Thread.currentThread().getName() + ":";
		long endTime = System.currentTimeMillis();
		System.out.println(infoMsg + result + "(用时" + (endTime - startTime) / 1000 + "秒)");
	}
	
	@Override
	protected void finalize() throws Throwable {
		es.shutdownNow();
		super.finalize();
	}

}


上一篇:WIN7中修改Jar文件打开方式的方法


下一篇:tcp/http类nginx服务器keepalive_requests数据丢失问题