代码如下
import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.FutureTask; /** * @author lzq * @data 2020/4/30 0030 - 下午 4:02 */ public class Test2 { public static void mAIn(String[] args) throws ExecutionException, InterruptedException { MyThread thread=new MyThread(); FutureTask task = new FutureTask(thread); new Thread(task,"a").start(); new Thread(task,"b").start(); System.out.println(task.get()); } } class MyThread implements Callable<String> { @Override public String call() { System.out.println("实现callable"); return "得到返回值"; } }
执行结果为:
上面是使用Callable接口简单实现多线程,使用这个接口要使用FutrueTask类作为简单的适配类,因为Thread构造方法只能接受Runnable接口参数,下面源码中看出FutrueTask的对象为什么也能作为Runnable型参数传给Thread构造方法
再分析一下结果,可以看到明明启动了a,b两个线程,但是只输出了一个线程的结果,这是因为运行的结果会被缓存,使得线程的执行效率变高。还有一点就是获取线程返回值的get方法可能会产生阻塞,一般放在最后或者使用异步通信来处理。