e盘网站建设/怎么优化自己网站的关键词

e盘网站建设,怎么优化自己网站的关键词,网络推广方案的工作安排,网站建设与网络编辑综合实训课程指导手册pdf阻塞队列:原理、应用及实现 什么是阻塞队列以生产消费者模型形象地理解阻塞队列阻塞队列实现生产消费者模型模拟实现阻塞队列实现生产消费者模型 什么是阻塞队列 阻塞队列是一种特殊且实用的队列数据结构,它同样遵循 “先进先出” 的原则。与普通队列不…

阻塞队列:原理、应用及实现

    • 什么是阻塞队列
    • 以生产消费者模型形象地理解阻塞队列
    • 阻塞队列实现生产消费者模型
    • 模拟实现阻塞队列实现生产消费者模型

什么是阻塞队列

阻塞队列是一种特殊且实用的队列数据结构,它同样遵循 “先进先出” 的原则。与普通队列不同的是,阻塞队列是线程安全的,这使得它在多线程编程中扮演着重要角色。

阻塞队列具有以下两个关键特性:

  • 当队列已满时,如果有线程尝试将元素入队列,该线程将会被阻塞,直到有其他线程从队列中取走元素,使得队列腾出空间。
  • 当队列为空时,若有线程试图从队列中出队列,此线程也会被阻塞,直至有其他线程向队列中插入新的元素。

阻塞队列的一个经典应用场景便是 “生产者消费者模型”。这种模型在软件开发中被广泛使用,能够有效地协调不同线程之间的工作,提高程序的性能和稳定性。

以生产消费者模型形象地理解阻塞队列

为了更直观地理解阻塞队列的工作原理,我们以一个具体的生产消费者场景为例。假设有四个生产者线程和一个消费者线程:

  • 每个生产者线程每单位时间能够生产 4 个面包。
  • 消费者线程每单位时间只能取走 1 个面包。
    在这里插入图片描述

在这种情况下,由于生产者的生产速度远快于消费者的消费速度,每单位时间会有 3 个面包进入阻塞队列,等待消费者线程来取。并且在这个过程中,生产者线程不会停止生产。
在这里插入图片描述

随着时间的推移,当阻塞队列被填满,没有空位时,生产者线程就会因为无法继续入队列而停止生产,直到消费者线程从队列中取走一些面包,腾出空间。
在这里插入图片描述

阻塞队列实现生产消费者模型

在 Java 中,BlockingQueue接口及其实现类为我们提供了便捷的方式来实现生产消费者模型。以下是 BlockingQueue 的构造方法示例图:

在这里插入图片描述

下面通过一段 Java 代码来具体实现生产消费者模型(为了便于观察和理解,我们创建了一个固定容量的阻塞队列):

import java.util.Random;
import java.util.concurrent.BlockingDeque;
import java.util.concurrent.LinkedBlockingDeque;public class Main {public static void main(String[] args) {Random random = new Random();// 首先创建一个阻塞队列,容量为 10BlockingDeque<Integer> blockingDeque = new LinkedBlockingDeque<>(10);// 创建生产者线程Thread t1 = new Thread(() -> {while (true) {try {int value = random.nextInt(100);System.out.println("生产元素:" + value);blockingDeque.put(value);} catch (InterruptedException e) {throw new RuntimeException(e);}}});// 创建消费者线程Thread t2 = new Thread(() -> {while (true) {try {System.out.println("消费元素:" + blockingDeque.take());Thread.sleep(1000);} catch (InterruptedException e) {throw new RuntimeException(e);}}});t1.start();t2.start();}
}

通过上述代码,生产者线程不断生产随机整数并放入阻塞队列,而消费者线程则从队列中取出元素并打印,同时每隔 1 秒消费一次,模拟实际的消费速度。
在这里插入图片描述

模拟实现阻塞队列实现生产消费者模型

除了使用 Java 提供的现成阻塞队列实现类,我们还可以自己模拟实现一个固定容量的阻塞队列。在这个实现过程中,需要重点关注以下三个方面:

  1. 确保线程安全,避免多个线程同时访问队列时出现数据不一致的问题。
  2. 当队列为空时,消费者线程需要阻塞等待,直到队列中有新的元素可供消费。
  3. 当队列为满时,生产者线程需要阻塞等待,直到队列中有元素被消费,腾出空间。

以下是模拟实现的代码:

public class MyBlockqueue {// 队列的最大容量int max = 10;// 创建一个固定容量的数组来存储队列元素int[] arr;// 记录队列中已有元素的个数int num;// 队列头元素的下标,遵循先进先出原则int first;// 队列尾元素的下标,遵循后进后出原则int end;public MyBlockqueue(int max) {this.max = max;arr = new int[max];}// 模拟实现入队列操作public void put(int x) throws InterruptedException {// 检查队列是否已满while (num >= max) {// 如果已满,当前线程进入阻塞状态synchronized (this) {wait();}}// 队列未满,添加元素synchronized (this) {arr[end] = x;end = (end + 1) % max;num++;// 唤醒其他可能在等待的线程notify();}}// 模拟实现出队列操作public Integer take() throws InterruptedException {// 检查队列是否为空while (num == 0) {// 如果为空,当前线程进入阻塞状态synchronized (this) {wait();}}// 队列不为空,取出元素synchronized (this) {int tmp = arr[first];first = (first + 1) % max;num--;// 唤醒其他可能在等待的线程notify();return tmp;}}
}

接下来,我们使用这个自定义的阻塞队列来实现生产消费者模型:

import java.util.Random;public class Main {public static void main(String[] args) {Random random = new Random();// 创建一个自定义的阻塞队列,容量为 10MyBlockqueue blockingDeque = new MyBlockqueue(10);// 创建生产者线程Thread t1 = new Thread(() -> {while (true) {try {int value = random.nextInt(100);System.out.println("生产元素:" + value);blockingDeque.put(value);} catch (InterruptedException e) {throw new RuntimeException(e);}}});// 创建消费者线程Thread t2 = new Thread(() -> {while (true) {try {System.out.println("消费元素:" + blockingDeque.take());Thread.sleep(1000);} catch (InterruptedException e) {throw new RuntimeException(e);}}});t1.start();t2.start();}
}

在这里插入图片描述

通过上述代码,我们成功地模拟实现了一个阻塞队列,并基于它构建了生产消费者模型,帮助我们更深入地理解阻塞队列的工作原理和应用场景。

希望这篇博客能让你对阻塞队列有更全面、深入的认识!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/74262.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【开源宝藏】30天学会CSS - DAY5 第五课 脉冲动画

以下是一个完整的渐进式教程&#xff0c;拆解如何用 HTML CSS 构建“Pulsar”水波脉冲动画。通过阅读&#xff0c;你将理解每个核心属性与关键帧如何配合&#xff0c;让一个小圆不断散发动态波纹&#xff0c;并且文字始终停留在圆心。 第 0 步&#xff1a;项目概览 文件结构示…

2060 裁纸刀

2060 裁纸刀 ⭐️难度&#xff1a;简单 &#x1f31f;考点&#xff1a;2022、规律、思维 &#x1f4d6; &#x1f4da; import java.util.Arrays; import java.util.LinkedList; import java.util.Queue; import java.util.Scanner;public class Main {static int N 100010…

python学习笔记--实现简单的爬虫(一)

任务&#xff1a;爬取豆瓣最受欢迎的250个电影的资料 链接&#xff1a;豆瓣电影 Top 250 用浏览器打开后&#xff0c;使用F12或鼠标右键--检查&#xff0c;查看网页的源代码&#xff0c;分析网页结构&#xff0c;如下图所示&#xff1a; 分析后得知&#xff1a; 1.电影名位于…

Cursor+Claude-3.5生成Android app

一、Android Studio下载 https://developer.android.com/studio?hlzh-tw#get-android-studio 等待安装完成 二、新建工程 点击new project 选择Empty Activity 起一个工程名 当弹出这个框时 可以在settings里面选择No proxy 新建好后如下 点击右边模拟器&#xff0c…

Java EE(15)——网络原理——TCP协议解析一

一.确认应答/(确认)序列号 接收方接收到数据后&#xff0c;向发送方返回一个确认信号(ack)&#xff0c;告诉发送方数据被成功接收。ACK报文段只是作为确认使用的&#xff0c;一般来说不携带应用层数据&#xff08;载荷&#xff09;&#xff0c;也就是说只有报头部分。但有可能…

C#单例模式

单例模式 (Singleton),保证一个类仅有一个实例&#xff0c;并提供一个访问它的全局访问点。通常我们可以让一个全局变量使得一个对象被访问&#xff0c;但它不能防止你实例化对个对象&#xff0c;一个最好的办法就是&#xff0c;让类自身负责保护它的唯一实例。这个类可以保证没…

NO.55十六届蓝桥杯备战|排序|插入|选择|冒泡|堆|快速|归并(C++)

插⼊排序 插⼊排序(Insertion Sort)类似于玩扑克牌插牌过程&#xff0c;每次将⼀个待排序的元素按照其关键字⼤⼩插⼊到前⾯已排好序的序列中&#xff0c;按照该种⽅式将所有元素全部插⼊完成即可 #include <iostream> using namespace std; const int N 1e5 10; …

【Oracle资源损坏类故障】:详细了解坏块

目录 1、物理坏块与逻辑坏块 1.1、物理坏块 1.2、逻辑坏块 2、两个坏块相关的参数 2.1、db_block_checksum 2.2、db_block_checking 3、检测坏块 3.1、告警日志 3.2、RMAN 3.3、ANALYZE 3.4、数据字典 3.5、DBVERIFY 4、修复坏块 4.1、RMAN修复 4.2、DBMS_REPA…

计算机网络高频(二)TCP/IP基础

计算机网络高频(二)TCP/IP基础 1.什么是TCP/IP⭐⭐ TCP/IP是一种网络通信协议,它是互联网中最常用的协议之一。TCP/IP有两个基本的协议:TCP(传输控制协议)和IP(互联网协议)。 TCP(Transmission Control Protocol,传输控制协议)是一种可靠的、面向连接的协议。它负…

【蓝桥杯】12111暖气冰场(多源BFS 或者 二分)

思路 这题可以用BFS做&#xff0c;也可以用二分来做。 用二分这里只提供一个思路&#xff1a;对时间来二分查找&#xff0c;check函数就是检查在特定的时间 t 0 t_0 t0​内每一个暖气炉的传播距离能否覆盖所有格子。 用BFS做&#xff1a; 由几个点开始向外扩散&#xff0c;知道…

DeepSeek自学手册:《从理论(模型训练)到实践(模型应用)》|73页|附PPT下载方法

导 读INTRODUCTION 今天分享是由ai呀蔡蔡团队带来的DeepSeek自学手册&#xff1a;《从理论&#xff08;模型训练&#xff09;到实践&#xff08;模型应用&#xff09;》&#xff0c;这是一篇关于DeepSeek模型训练、应用场景及替代方案的综合指南文章&#xff0c;主要介绍了Deep…

QT软件匠心开发,塑造卓越设计服务

在当今这个数字化飞速发展的时代&#xff0c;软件已经成为我们生活中不可或缺的一部分。而QT&#xff0c;作为一款跨平台的C图形用户界面应用程序开发框架&#xff0c;凭借其强大的功能和灵活性&#xff0c;在众多软件开发工具中脱颖而出。我们深知&#xff0c;在软件开发领域&…

标贝科技入选2025年市级数据要素市场化配置改革“揭榜挂帅”名单

近日&#xff0c;山东省大数据局、青岛市大数据局公布2025年数据要素市场化配置改革“揭榜挂帅”名单。标贝科技联合崂山区电子政务和大数据中心申报的“政务热线通话录音数据价值挖掘与权益保护”项目成功入选。这一成果不仅彰显了标贝科技在数据领域的创新实力&#xff0c;更…

Flutter TextField 从入门到精通:掌握输入框的完整指南

目录 1. 引言 2. TextField 的基本用法 3. 主要属性 4. 自定义 TextField 样式 4.1 自定义边框与提示文本 4.2 增加前缀/后缀图标 4.3 只允许输入数字 4.4 表单验证系统 4.5 动态样式修改 4.6 防抖搜索&#xff08;Debounce&#xff09; 5. 结论 相关推荐 1. 引言…

MyBatis-Plus 自动填充:优雅实现创建/更新时间自动更新!

目录 一、什么是 MyBatis-Plus 自动填充&#xff1f; &#x1f914;二、自动填充的原理 ⚙️三、实际例子&#xff1a;创建时间和更新时间字段自动填充 ⏰四、注意事项 ⚠️五、总结 &#x1f389; &#x1f31f;我的其他文章也讲解的比较有趣&#x1f601;&#xff0c;如果喜欢…

arduino R4 SD卡读写测试

使用买来的 st7789LCD 显示器背面就带着一个 tf 卡槽&#xff0c;可以直接连接 tf 卡。使用 Sdfat 库就可以实现对 sd 卡的读写操作。这里尝试测试 sd 卡的读写功能。 LCD 显示器的初始化 //定义LCD的对象 Adafruit_ST7789 tft Adafruit_ST7789(TFT_CS, TFT_DC, TFT_RST);tf…

【武汉·4月11日】Parasoft联合光庭信息研讨会|邀您共探AI赋能新机遇

Parasoft联合光庭信息Workshop邀您共探AI赋能新机遇 AI浪潮已至&#xff0c;你准备好了吗&#xff1f; 在智能网联汽车飞速发展的今天&#xff0c;AI技术正以前所未有的速度重塑行业生态。如何把握AI机遇&#xff0c;赋能企业创新&#xff1f; 4月11日&#xff0c;自动化软件…

防火墙带宽管理

拓扑 配置 [fw]interface GigabitEthernet 0/0/0 [fw-GigabitEthernet0/0/0]service-manage all permit [fw]interface GigabitEthernet 1/0/0 [fw-GigabitEthernet1/0/0]ip address 12.0.0.1 24 [fw]interface GigabitEthernet 1/0/1 [fw-GigabitEthernet1/0/1]ip ad…

一人系统 之 为什么要做一人系统?

一人系统 之 赚钱认知篇&#xff08;下&#xff09; 本文 2119个字&#xff0c;大概阅读时间 16分钟。 在上一篇文章中&#xff0c;主要讲了以下三个内容&#xff1a; 什么是好的工作&#xff1f;时薪高&#xff0c;并且有能力提升&#xff0c;而且最终可以独立创业的工作&…

基于springboot的电影院管理系统(源码+lw+部署文档+讲解),源码可白嫖!

摘要 互联网技术的成熟和普及&#xff0c;势必会给人们的生活方式带来不同程度的改变。越来越多的经营模式中都少不了线上运营&#xff0c;互联网正强力推动着社会和经济发展。国人对民族文化的自信和不同文化的包容&#xff0c;再加上电影行业的发展&#xff0c;如此繁荣吸引…