您的位置:首页 > 编程语言 > Java开发

java:多线程基础之Runnable、Callable与Thread

2014-11-13 15:28 381 查看
java.lang包下有二个非常有用的东西:Runnable接口与Thread类,Thread实现了Runnable接口(可以认为Thread是Runnable的子类),利用它们可以实现最基本的多线程开发。

一、Runnable入门示例

package com.cnblogs.yjmyzz;

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask;

public class RunnableDemo9 {

public static void main(String[] args) throws InterruptedException,
ExecutionException {

FutureTask<String> task = new FutureTask<String>(
new Callable<String>() {
public String call() throws InterruptedException {
System.out.println("FutureTask开始处理...");
Thread.sleep(1000);
return "hello world";
}
});
System.out.println("FutureTask准备开始...");
new Thread(task).start();
System.out.println("其它处理开始...");
Thread.sleep(1000);
System.out.println("其它处理完成...");
System.out.println("FutureTask处理结果:" + task.get());
System.out.println("全部处理完成");
}

}


View Code
二个注意点:

a) FutureTask使用Callable接口取得返回值,因为结果可能并不需要立刻返回,而是等到未来真正需要的时候,而Runnable并不提供返回值

b) FutureTask通过Thread的start()调用后,马上就开始处理,但并不阻塞后面的线程,在真正需要处理结果的时候,调用get()方法,这时如果FutureTask本身的处理尚未完成,才会阻塞,等待处理完成

刚才的运行结果:

FutureTask准备开始...
FutureTask开始处理...
其它处理开始...
其它处理完成...
FutureTask处理结果:hello world
全部处理完成

可以看到,“其它处理”并未被FutureTask阻塞,但FutureTask其实已经在后台处理了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐