大话-阻塞队列(阻塞 唤醒),生产者、消费者的实现

队列先进先出的一种数据结构,那什么是阻塞队列呢?

从名字可以看出阻塞队列其实也就是队列的一种特殊情况。
在这里插入图片描述
从上面这张图我们会发现这样的规律:

(1)当阻塞队列为空时,从队列中获取元素的操作将会被阻塞,就好比餐馆休息区没人了,此时不能接纳新的顾客了。换句话,肚子为空的时候也没东西吃。

(2)当阻塞队列满了,往队列添加元素的操作将会被阻塞,好比餐馆的休息区也挤满了,后来的顾客只能走了。

从上面的概念我们类比到线程中去,我们会发现,在某些时候线程可能不能不阻塞,因为CPU内核就那么几个,阻塞现状更加说明了资源的利用率高,换句话来说,阻塞其实是一个好事。

阻塞队列应用最广泛的是生产者和消费者模式。在没有阻塞队列前是这样子的,
版本1:synchronized ,wait,notifyAll 配合实现线程阻塞、唤醒

class XiaoFeiSyn{
   
    private int number=0;

    public synchronized void product() throws Exception {
   
        try {
   
            while (number != 0) {
   
                //阻塞
                this.wait();
            }
            number++;
            System.out.println(Thread.currentThread().getName() + " 生产消息...");
            this.notifyAll();
        }
        catch (Exception e) {
   
            e.printStackTrace();

        }
    }

    public synchronized void consume () throws Exception {
   
            try {
   
                while (number == 0) {
   
                    //阻塞
                    this.wait();
                }
                number--;
                System.out.println(Thread.currentThread().getName() + " 消费消息...");
                this.notifyAll();
            }
            catch (Exception e) {
   
                e.printStackTrace();
            }
    }
}

	public static void test6(){
   
        XiaoFeiSyn fei=new XiaoFeiSyn();
        new Thread(()->{
   
            try {
   
                for (int i = 0; i < 10; i++) {
   
                    fei.product();
                }
            }
            catch (Exception e) {
   
                e.printStackTrace();
            }finally {
   
            }

        }, "AA").start();
        new Thread(()-
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
stable-diffusion-webui是一个稳定的扩散网络用户界面,该项目的开发可以分为三个主要步骤。 首先,我们需要搭建一个基本的Web界面框架。我们可以选择使用现成的Web开发框架,如React或Vue.js。这些框架提供了一套良好的组件化和状态管理机制,方便我们构建一个复杂而稳定的用户界面。我们需要使用HTML和CSS来设计和布局页面,并使用框架提供的组件和API来实现各种功能和交互。 接下来,我们需要连接界面与稳定的扩散网络后端。我们可以使用HTTP请求来与后端进行通信,获取和发送数据。为了保持稳定性,我们可以使用异步请求,以避免界面在等待响应时冻结。我们可以使用现有的HTTP库,如Axios或Fetch,来简化请求的处理。同时,我们还需要进行错误处理和数据验证,以确保数据的准确性和完整性。 最后,我们需要为界面添加一些功能和特性。这可能包括用户认证和授权,数据可视化和图表展示,以及与其他用户的实时交互和通信。我们可以使用现有的库和工具,如Chart.js和Socket.io,来实现这些功能。同时,我们还需要进行一些性能和安全性方面的优化,以确保界面的快速响应和数据的安全性。 总之,开发一个简单的stable-diffusion-webui需要搭建基本的Web界面框架,连接后端,并为界面添加功能和特性。通过以上步骤,我们可以实现一个稳定而功能丰富的扩散网络用户界面。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值