Java1.6多线程之同步方法

简介: <pre name="code" class="java">package com.starit.open.main;import java.util.ArrayList;import java.util.List;import java.util.concurrent.Callable;import java.util.concurrent.ExecutionException
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();
	}

}


相关文章
|
6月前
|
Java
Java语言实现字母大小写转换的方法
Java提供了多种灵活的方法来处理字符串中的字母大小写转换。根据具体需求,可以选择适合的方法来实现。在大多数情况下,使用 String类或 Character类的方法已经足够。但是,在需要更复杂的逻辑或处理非常规字符集时,可以通过字符流或手动遍历字符串来实现更精细的控制。
427 18
|
6月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
328 1
|
6月前
|
Java 编译器 Go
【Java】(5)方法的概念、方法的调用、方法重载、构造方法的创建
Java方法是语句的集合,它们在一起执行一个功能。方法是解决一类问题的步骤的有序组合方法包含于类或对象中方法在程序中被创建,在其他地方被引用方法的优点使程序变得更简短而清晰。有利于程序维护。可以提高程序开发的效率。提高了代码的重用性。方法的名字的第一个单词应以小写字母作为开头,后面的单词则用大写字母开头写,不使用连接符。例如:addPerson。这种就属于驼峰写法下划线可能出现在 JUnit 测试方法名称中用以分隔名称的逻辑组件。
299 4
|
6月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
327 1
|
6月前
|
编解码 Java 开发者
Java String类的关键方法总结
以上总结了Java `String` 类最常见和重要功能性方法。每种操作都对应着日常编程任务,并且理解每种操作如何影响及处理 `Strings` 对于任何使用 Java 的开发者来说都至关重要。
399 5
|
7月前
|
算法 安全 Java
除了类,Java中的接口和方法也可以使用泛型吗?
除了类,Java中的接口和方法也可以使用泛型吗?
234 11
|
7月前
|
Java 开发者
Java 函数式编程全解析:静态方法引用、实例方法引用、特定类型方法引用与构造器引用实战教程
本文介绍Java 8函数式编程中的四种方法引用:静态、实例、特定类型及构造器引用,通过简洁示例演示其用法,帮助开发者提升代码可读性与简洁性。
|
7月前
|
存储 Oracle Java
|
7月前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案
Java 数据库 Spring
312 0