多线程 ---> 生产者和消费者1


 生产者   和  消费者
 ---------------------------
 1/ 生产者:
 2/ 消费者:
----------------------------
 Object    ===>>>>     notify()  唤醒该线程
                        waitwait()  等待
                        --------------------------------
                        消费者应等待生产者生产后消费.....

--------------------------------

相关资料连接

========================================================

练习Demo: 电影院录入电影 消费者消费电影 资源 ==> 电影类

    要求: 电影生产两部电影后,消费者开始消费

============================================================

     思路: 1/ 生产者和消费者 实现接口 Runable 重写run方法 做简单练习Demo

```      2/ 资源是共享的 , 需要在资源类,即电影类中加入方法 生产电影 和消费电影的两个方法,同时为两个方法上锁

       3/ 上锁后,还需借助父类的 wait() 和 notify() 两个方法来控制线程的工作状态..

============================================================

代码:

-------------------------------------------------------------

生产者:

public class ProductThread implements Runnable {
    private Movie movie = null;
    private boolean flag = false ;

    public ProductThread(Movie movie) {
        this.movie = movie;
    }

    @Override
    public void run() {
        //模拟录入电影    循环录入二十遍电影    两部电影交替录入
        for ( int i = 0 ; i < 20 ; i++  ) {
            if (flag) {
                this.movie.setMovie("变形金刚","科幻电影");
                flag = false;
            }else {
                this.movie.setMovie("僵尸先生","恐怖电影");
                 flag = true;
            }
        }
    }
}


+++++++++++++++++++++++++++++++++++

消费者:

public class CastThread implements Runnable {
    private Movie movie = null;

    public CastThread(Movie movie) {
        this.movie = movie;
    }

    @Override
    public void run() {
        //循环显示20此购买信息  模拟消费
        for (int i = 0 ; i < 20 ; i ++ ) {
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            this.movie.getMovie();
        }
    }
}


++++++++++++++++++++++++++++++++++++

电影类:

public class Movie {
    private String name;
    private String info;
    private boolean flag = true; // 标志位  控制生产  true  表示当前没有电影  需要生产

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getInfo() {
        return info;
    }

    public void setInfo(String info) {
        this.info = info;
    }

    public synchronized void setMovie(String name, String info) {
        if (!flag) {
            System.out.println(flag);
            try {
                super.wait();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        this.name = name;
        try {
            Thread.sleep(100);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        this.info = info;
        flag = false;  //重置标志位,让消费者消费
        super.notify();
    }


    public synchronized void getMovie() {
        if (flag) {
            try {
                super.wait();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        System.out.println(this.getName() + "-消费-" + this.getInfo());
        flag = true;
        super.notify();

    }
}


+++++++++++++++++++++++++++++++++++++

测试类:

public class MovieTest {
    public static void main(String[] args) {
        Movie movie  =  new Movie();
        Thread scz = new Thread(new ProductThread(movie));
        Thread xfz = new Thread(new CastThread(movie));
        scz.start();
        xfz.start();
    }
}






 生产者   和  消费者
 ---------------------------
 1/ 生产者:
 2/ 消费者:
----------------------------
 Object    ===>>>>     notify()  唤醒该线程
                        waitwait()  等待
                        --------------------------------
                        消费者应等待生产者生产后消费.....

--------------------------------

相关资料连接

========================================================

练习Demo: 电影院录入电影 消费者消费电影 资源 ==> 电影类

    要求: 电影生产两部电影后,消费者开始消费

============================================================

     思路: 1/ 生产者和消费者 实现接口 Runable 重写run方法 做简单练习Demo

```      2/ 资源是共享的 , 需要在资源类,即电影类中加入方法 生产电影 和消费电影的两个方法,同时为两个方法上锁

       3/ 上锁后,还需借助父类的 wait() 和 notify() 两个方法来控制线程的工作状态..

============================================================

(Kriging_NSGA2)克里金模型结合多目标遗传算法求最优因变量及对应的最佳自变量组合研究(Matlab代码实现)内容概要:本文介绍了克里金模型(Kriging)与多目标遗传算法NSGA-II相结合的方法,用于求解最优因变量及其对应的最佳自变量组合,并提供了完整的Matlab代码实现。该方法首先利用克里金模型构建高精度的代理模型,逼近复杂的非线性系统响应,减少计算成本;随后结合NSGA-II算法进行多目标优化,搜索帕累托前沿解集,从而获得多个最优折衷方案。文中详细阐述了代理模型构建、算法集成流程及参数设置,适用于工程设计、参数反演等复杂优化问题。此外,文档还展示了该方法在SCI一区论文中的复现应用,体现了其科学性与实用性。; 适合人群:具备一定Matlab编程基础,熟悉优化算法数值建模的研究生、科研人员及工程技术人员,尤其适合从事仿真优化、实验设计、代理模型研究的相关领域工作者。; 使用场景及目标:①解决高计算成本的多目标优化问题,通过代理模型降低仿真次数;②在无法解析求导或函数高度非线性的情况下寻找最优变量组合;③复现SCI高水平论文中的优化方法,提升科研可信度与效率;④应用于工程设计、能源系统调度、智能制造等需参数优化的实际场景。; 阅读建议:建议读者结合提供的Matlab代码逐段理解算法实现过程,重点关注克里金模型的构建步骤与NSGA-II的集成方式,建议自行调整测试函数或实际案例验证算法性能,并配合YALMIP等工具包扩展优化求解能力。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值