美文网首页写作与程序
java初入多线程18

java初入多线程18

作者: 胖琪的升级之路 | 来源:发表于2017-10-30 10:48 被阅读7次

Future 模式

  • 该模式核心思想是异步调用。
Future 异步调用模式
public class Main {
    public static void main(String[] args) {
        Client client  = new Client() ;
        
        Data data = client.request("name");
        System.out.println("请求完毕");
        try {
            Thread.sleep(2000);
        } catch (Exception e) {
        }
        
        System.out.println("数据  = " + data.getResult());
    }
}
public class Client {
    public Data request(final String queryStr){
        final FutureData future = new FutureData() ;
        new Thread(){
            public void run() {
                RealData realData = new RealData(queryStr);
                future.setRealData(realData);
            }   ;
        }.start();  
        return future ;
    }   
}
public class RealData implements Data {
    protected  final String result ;
    public RealData(String result) {
        super();
        StringBuffer buffer =new StringBuffer();
        for(int i = 0 ; i < 10 ; i++){
            buffer.append(result+" ");
            try {
                Thread.sleep(100);
            } catch (Exception e) {     
            }
        }   
        this.result = buffer.toString();
    }
    @Override
    public String getResult() {
        return result;
    }
}
public interface Data {
    public String getResult();
}
public class FutureData implements Data {
    protected boolean isReady = false ;
    protected RealData  realData = null ;
    public synchronized  void setRealData(RealData realData) {
        if(isReady){
            return ;
        }
        this.realData = realData;
        isReady = true ;
        notifyAll();
    }
    @Override
    public synchronized String getResult() {
        while(!isReady){
            try {
                wait();
            } catch (Exception e) {
            }
        }
        return realData.result; 
    }
}

jdk 中的Future 模式

内置实现Future
public class FurureMain {

    public static void main(String[] args)  throws Exception{
        //构造任务
        FutureTask<String> future = new FutureTask<String>( new RealDataCall("a"));
        ExecutorService executor =Executors.newFixedThreadPool(1);
        executor.submit(future);
        System.out.println("请求完毕");
        try {   
            Thread.sleep(2000);
        } catch (Exception e) {
            // TODO: handle exception
        }   
        System.out.println("数据= : "+ future.get());
    }   
}
public class RealDataCall implements Callable<String> {
    private String para ;
    public RealDataCall(String para) {
        super();
        this.para = para;
    }
    @Override
    public String call() throws Exception {
        StringBuffer buffer =new StringBuffer();
        for(int i = 0 ; i < 10 ; i++){
            buffer.append(para+" ");
            try {
                Thread.sleep(100);
            } catch (Exception e) {         
            }
        }
        return buffer.toString();
    }
}
  1. 在这里面我们首先创建FutureTask对象实例, 表示该任务是有返回值的。
  2. 第二步 使用Callable 产生数据。
  3. 提交任务到线程池。 作为任务的简单提交。用get把结果查出来

相关文章

  • java初入多线程18

    Future 模式 该模式核心思想是异步调用。 jdk 中的Future 模式 在这里面我们首先创建FutureT...

  • java初入多线程4

    线程中断 概念 :让目标线程停止执行,但是是高知目标线程希望线退出,具体退出由目标线程自己决定。 相关的方法,暂时...

  • java初入多线程17

    使用Disruptor 实现消费者和生产者 我们在主方法操作中将缓冲区设置成1024 , 在这里有四个消费者, 有...

  • java初入多线程11

    核心线程池的内部实现机制。 阿里巴巴 code检验推荐自己实现线程池的创建。不是使用Executors的创建方法。...

  • java初入多线程12

    自定义线程创建:ThreadFactory 我们原先用的线程池ThreadPoolExecutor 里面的线程都...

  • java初入多线程10

    线程阻塞工具类 :LockSupport LockSupport 是一个非常实用的线程阻塞工具, 可以在线程内任意...

  • java初入多线程7

    同步控制 synchronized 扩展:重入锁 重入锁来代替synchronized,在Jdk1.6以后 syn...

  • java初入多线程14

    接下来几章说的是锁的优化和注意事项问题。 减小锁持有的时间 对于在方法执行的过程中有的步骤不需要进行同步,那么就在...

  • java初入多线程15

    无锁的线程安全整数: AtomicInteger 方法介绍public final int get(); 取得当前...

  • java初入多线程13

    并发集合简介 ConcurrentHashMap : 线程安全的HashMap; CopyOnWriteArray...

网友评论

    本文标题:java初入多线程18

    本文链接:https://www.haomeiwen.com/subject/pcfppxtx.html