线程同步 生产者消费者小例子

本文介绍了一个使用Java实现的生产者消费者模式案例。该程序通过一个容量为6的产品容器,演示了如何协调生产者线程与消费者线程的工作,确保容器不会溢出也不会为空。文章详细解释了synchronized关键字的作用、wait()与notify()方法的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package abit;public class classicThread { public static void main(String[] args){ Container c=new Container(); Producer p=new Producer(c); Consumer c2=new Consumer(c); new Thread(p).start(); new Thread(c2).start(); }}class Product{int id;Product(int id){this.id=id;}public String toString(){return "产品"+id;}}class Container{int index=0;Product[] product=new Product[6];//规定这个容器大小是6个public synchronized void add(Product p){while(index==product.length){try{this.wait();//Container c所在的线程等待}catch(Exception e){}}//this.notify();product[index]=p;index++;}public synchronized Product remove(){while(index==0){try{this.wait();}catch(Exception e){}}this.notify();index--;return product[index];}}class Producer implements Runnable{Container c=null;Producer(Container c){this.c=c;}public void run(){for(int i=0;i<20;i++){Product p=new Product(i);c.add(p);System.out.println("生产了"+p);// try{// Thread.sleep(1000);// }catch(Exception e){}}}}class Consumer implements Runnable{Container c=null;Consumer(Container c){this.c=c;}public void run(){for(int i=0;i<20;i++){Product p=c.remove();System.out.println("----消费了"+p);try{Thread.sleep(2000);}catch(Exception e){}}}}容器只能装6个,在run中生产20个,然后不断取走,保证不会超过容器的大小(让线程睡眠只是让效果更佳明显而已)能够放入的临界条件是while(index==product.length),能够取走的临界条件是while(index==0)执行start()的时候其实就是在run()中调用了class Container中的方法class Container 中的方法都是只能是一个线程进入的,wait()的时候会释放锁。public final void notify()唤醒在此对象监视器上等待的单个线程。如果所有线程都在此对象上等待,则会选择唤醒其中一个线程。选择是任意性的,并在对实现做出决定时发生。线程通过调用其中一个 wait 方法,在对象的监视器上等待。 public final void wait() throws InterruptedException在其他线程调用此对象的 notify() 方法或 notifyAll() 方法前,导致当前线程等待。换句话说,此方法的行为就好像它仅执行 wait(0) 调用一样。 这个例子中,这个对象其实一直是Container c, add()方法睡着时,另外一条线程即消费者线程调用了this.notify(),是add()里的现在不再wati,而继续执行。
资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领域,自动化构建与发布是提升开发效率和项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建与发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排与可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称和描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本和预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建和发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push package和Deploy/Rollback。每个阶段都可以根据实际需求进行配置和调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率和项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试和部署,从而提高项目的整体质量和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值