图解java多线程设计模式学习第九章Future模式

假设我们去蛋糕店买蛋糕。下单后,店员一边递给我们提货单,一边说“请您傍晚再来取蛋糕”。到了傍晚,我们就拿着提货单取蛋糕。这时,店员会先和我们说“您的蛋糕已经做好了”。然后将蛋糕递给了我们。

Future的意思是未来,期货。假设有一个方法需要花费很长时间才能获取运行结果,那么,与其一直等待结果,不如先拿一张“提货单”。获取提货单并不耗费时间。这里的“提货单”我们就称为Future角色。

获取Future角色的线程会在稍后使用Future角色来获取运行结果。这与凭着提货单去取蛋糕非常相识。如果运行结果已经出来了,那么直接获取即可;如果运行结果还没有出来,那么需要等待结果出来。

package com.future;


public interface Data {

    public abstract String getContent();
    
}

package com.future;

public class FutureData implements Data{

    private RealData realData;
    private boolean ready = false;
    public synchronized void setRealData(RealData realData){
        if(ready){
            return;
        }
        this.realData = realData;
        this.ready = true;
        notifyAll();
    }
    @Override
    public synchronized String getContent() {
        // TODO Auto-generated method stub
        while(!ready){
            try {
                wait();
            } catch (Exception e) {
                // TODO: handle exception
            }
        }
        return realData.getContent();
    }

}

package com.future;

public class Host {

    public Data request(final int count, final char c){
        System.out.println(" request(" + count + ", "+ c + ") BEGIN");
        //(1)创建FutureData的实例
        final FutureData future = new FutureData();
        //(2)启动一个线程, 用于创建RealData 的实例
        new Thread(){
            public void run() {
                RealData realData = new RealData(count, c);
                future.setRealData(realData);
            };
        }.start();
        System.out.println(" request(" + count + ", " + c + ") END");
        //(3)返回FutureData的实例
        return future;
    }
}

package com.future;

public class RealData implements Data{

    private final String content;
    public RealData(int count, char c) {
        System.out.println("        making RealData(" + count + ", " + c + ") BEGIN");
        char [] buffer = new char[count];
        for(int i = 0; i < count;i++){
            buffer[i] = c;
            try {
                Thread.sleep(1000);
            } catch (Exception e) {
                // TODO: handle exception
            }
        }
        System.out.println("        making RealData(" + count + ", " + c + ") END");
        this.content = new String(buffer);
    }

    @Override
    public String getContent() {
        return content;
    }
}

package com.future;

public class Main {

    public static void main(String[] args) {
        Host host = new Host();
        Data data1 = host.request(10, 'A');
        Data data2 = host.request(20, 'B');
        Data data3 = host.request(30, 'C');
        try {
            Thread.sleep(1000);
        } catch (Exception e) {
            // TODO: handle exception
        }
        System.out.println("data1 = " + data1.getContent());
        System.out.println("data2 = " + data2.getContent());
        System.out.println("data3 = " + data3.getContent());
    }
}

基于STM32F407,使用DFS算法实现最短迷宫路径检索,分为三种模式:1.DEBUG模式,2. 训练模式,3. 主程序模式 ,DEBUG模式主要分析bug,测量必要数据,训练模式用于DFS算法训练最短路径,并将最短路径以链表形式存储Flash, 主程序模式从Flash中….zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值