多线程的几种介绍

多线程的三种实现方式

1、继承Thread类,实现run方法

2、实现Runnable接口,实现接口中的run方法

3、实现callable接口(结合线程池使用)

接下来具体看第三种的使用,多线程求和

import java.util.concurrent.Callable;

/*
* 线程求和案例
*/
public class MyCallable implements Callable<Integer> {

private int number;

public MyCallable(int number) {
this.number = number;
}

@Override
public Integer call() throws Exception {    与run方法不同的是该方法具有返回值
int sum = 0;
for (int x = 1; x <= number; x++) {
sum += x;
}
return sum;
}

}

 

 

import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

/*
* 多线程实现的方式3:
* A:创建一个线程池对象,控制要创建几个线程对象。
* public static ExecutorService newFixedThreadPool(int nThreads)
* B:这种线程池的线程可以执行:
* 可以执行Runnable对象或者Callable对象代表的线程
* 做一个类实现Runnable接口。
* C:调用如下方法即可
* Future<?> submit(Runnable task)
* <T> Future<T> submit(Callable<T> task)
* D:我就要结束,可以吗?
* 可以。
*/
public class CallableDemo {
public static void main(String[] args) throws InterruptedException, ExecutionException {
// 创建线程池对象
ExecutorService pool = Executors.newFixedThreadPool(2);

// 可以执行Runnable对象或者Callable对象代表的线程
Future<Integer> f1 = pool.submit(new MyCallable(100));
Future<Integer> f2 = pool.submit(new MyCallable(200));

// V get()
Integer i1 = f1.get();
Integer i2 = f2.get();

System.out.println(i1);
System.out.println(i2);

// 结束
pool.shutdown();
}
}

 

posted @ 2016-07-25 23:50  huangssd  阅读(178)  评论(0编辑  收藏  举报