class RunClass implements Runnalble { @Override public void run() {...} } Thread newThread = new Thread(new RunClasss()); newThread.start();
固然,这里使用lambda表达式或者匿名类都是能够的,道理都同样java
//这里实际上是不对的,框架只是给人提供了必定方便的类库,但本质上仍是使用的上面两种方法。 3. 利用Callable<T>接口和Future框架建立线程 刚学习Java的人对这种方法可能了解很少,其步骤以下: 1. 建立新类实现Callable接口,并实现call()方法,该call方法将做位线程功能的执行代码(相似run,但run无返回值,call有返回值) 2. 建立Callable实现类的实例,使用FutureTask类来包装Callable对象,该FutureTask对象封装了该Callable对象的call方法的返回值 3. 使用FutureTask对象的get()方法来得到子线程执行结束后的返回值框架
import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.FutureTask; public class CallableDemo implements Callable<String> { private final String value; public CallableDemo(String value) { this.value = value; } @Override public String call() { return value; } static public void main(String[] args) { FutureTask<String> ft = new FutureTask<String>(new CallableDemo("Hello")); Thread t = new Thread(ft); t.start(); try { System.out.println(ft.get());//get()将阻塞直至获得结果 } catch (InterruptedException e) { e.printStackTrace(); } catch (ExecutionException e) { e.printStackTrace(); } } }
以上代码展现了Collable接口的使用,其与前两种方法的主要区别就是call()有返回值,调用Future的get()方法时,将产生阻塞,直至产生结果,这个特性能够用于后台计算等场景。ide