一.通过类变量和方法返回数
如下:
public class MyThread extends Thread
{
private String value;
public void run()
{
value = "通过成员变量返回数据";
}
public static void main(String[] args) throws Exception
{
MyThread thread = new MyThread();
thread.start();
System.out.println("value:" + thread.value);
}
}
但是运行上边代码基本不是你预期得到的结果,可能为
value:null
虽然在run方法中已经对value赋了值,而返回的却是null。发生这种情况的原因是调用
start方法后就立刻输出了value的值,而这里run方法还没有执行到为value赋值的语
句。
为了避免这种情况的发生,就需要等run方法执行完后才执行输出value的值。因此,我
们可以使用sleep方法将主线程进行延迟,如可以在thread.start()后加如下的语句:
sleep(1000);//等待一秒
这样做可以使主线程延迟1秒后再往下执行,但是对于这里来说太久了(有时可能
又太少,所以还要判断value是否为空)
虽然这样可以解决,但Java的线程模型为我们提供了更好的解决方案,这就是join
方法。
join的功能就是使用线程从异步执行变成同步执行。当线程变成同步执行后,就和
从普通的方法中得到返回数据没有什么区别了。如下语句
thread.start();
thread.join();
在thread.join()执行完后,线程thread的run方法已经退出了,也就是说线程thread已
经结束了。
注:join还有方法为thread.join(mills);最多等待时间,如果这个时间到了还没执行
完,下边代码也将继续执行。
三.Java5新增了Callable接口获得线程的返回值
实现Callable接口
import java.util.concurrent.Callable;
public class MyThread2 implements Callable<String> {
@Override
public String call() throws Exception {
String string="通过实现Callable借口返回";
return string;
}
}
这样调用
public static void main(String[] args) {
ExecutorService executorService=Executors.newCachedThreadPool();
Callable<String> callable=new MyThread2();
Future future=executorService.submit(callable);
try {
if(future.isDone()){
System.out.println(future.get());
}
} catch (Exception e) {
e.printStackTrace();
}
}
必须使用ExecutorService的submit方法来执行,返回一个Future对象
可以使用isDone()方法检测future是否完成,完成后可以调用get()方法获得future的
值, 如果直接调用get()方法,get()方法将阻塞值线程结束
(还有以下方法可以使用)
三.通过回调函数返回数据