一、當你想併發去執行一段代碼,可是還想獲取這段代碼的返回結果,那麼future多線程模式就能夠派上用場了,代碼實現以下。java
public class Client { public Data request() { final FutureData futureData = new FutureData(); new Thread(new Runnable() { @Override public void run() { futureData.setRealData(new RealData()); } }).start(); return futureData; } }
public interface Data { public String get(); }
public class FutureData implements Data{ private RealData realData = null; private boolean ok = false; public RealData getRealData() { return realData; } public synchronized void setRealData(RealData realData) { this.realData = realData; ok = true; notify(); } @Override public synchronized String get() { try { if(!ok) { this.wait(); } } catch (InterruptedException e) { e.printStackTrace(); } return realData.get(); } }
public class RealData implements Data { public RealData() { try { Thread.sleep(5000); } catch (InterruptedException e) { e.printStackTrace(); } } @Override public String get() { return "hello world!"; } }
public class main { public static void main(String[] args) { Client client = new Client(); Data data = client.request(); System.out.println(data.get()); } }
二、jdk1.5也提供了支持,代碼以下。多線程
public class RealData implements Callable<String> { public String call() throws Exception { int sum = 0; for(int i = 0; i < 100; i++) { sum += i; } return String.valueOf(sum); } }
public class main { public static void main(String[] args) throws InterruptedException, ExecutionException { FutureTask<String> futureTask = new FutureTask<String>(new RealData()); ExecutorService executor = Executors.newFixedThreadPool(1); executor.submit(futureTask); System.out.println(futureTask.get());; } }