/*生产者与消费者第二次敲,本人表示很郁闷,以后要经常读这个
* Condition 将Object类中的监视器(wait notify notifyAll)分解成不同的对象。例如condition_pro.await():
* condition_com.signal();这两个语句,分别是实例化了*_pro与*_com这两个对象,分别通过调用不同的对线程操作的方法来实现对线程的操作 */ package LockMethod;
import java.util.concurrent.locks.*;//condition,Lock接口都在此包中
class Resource2
{
private String name;//私有化商品名称
private int commodity=100;//私有化商品编号
private boolean flag=false;//定义一个boolean 型的线程切换标记
private Lock lock=new ReentrantLock();//建立一个锁的对象,多态,父类引用指向子类对象。
Condition condition_pro=lock.newCondition();//实例化一个Condition对象,Condition实例实质是绑定在一个锁上,此语句表示为特定的lock对象获取Condition对象
Condition condition_con=lock.newCondition();
public void set(String name) throws InterruptedException//await()方法抛出异常,API文档写出。set方法为生产者生产商品
{ lock.lock();//上锁。目的是同为生产者的t1,t2或者同为消费者的t3T4只能按序执行,不会发生一个商品生产了两次或者被消费了两次
try
{
while(flag)
condition_pro.await();//await()方法在API文档中有抛出异常,所以在方法上需要throws 一下
this.name=name+commodity++;
System.out.println(Thread.currentThread().getName()+"---producer"+this.name);
flag=true;//改变线程转换标记,使得当前线程再经过一次循环时可以挂那,因为生产一次,消费一次,不能使其再生产一次
condition_con.signal(); //唤醒消费者的线程,使得生产的上品被消费
}
/*catch(Exception e)
{ }*/
finally//其中代码为必须要执行的语句
{
lock.unlock();//finally中的代码是必须要执行的,解锁,以便让下一个线程可以执行。
}
}
public void out() throws InterruptedException//out方法为消费者消费商品
{
lock.lock();
try
{
while(!flag)//在该线程未被唤醒前,已经通过flag=true;改变了判断值。所以加!使得在消费者线程执行时不指向while中的awake();使其能println()顺利被消费
condition_con.await();
System.out.println(Thread.currentThread().getName()+"---消费者"+this.name);
flag=false;//改变标记,使消费者执行while语句,执行awake(),挂那,等待生产者生产一个商品后在次被唤醒
condition_pro.signal();//唤醒生产者线程
}
finally
{
lock.unlock();//解锁
}
}
}
class Producer2 implements Runnable//实现接口,调用线程要执行的run方法
{
private Resource Res;//私有一个Resource对象
Producer2(Resource Res)//构造函数,传入Resource对象
{
this.Res=Res;
}
public void run()//生产线程所要执行的代码
{
try
{
while(true)//while(true)记住格式,无线循环
Res.set("商品");//调用生产方法,生产产品
}
catch(Exception e)
{ }
}
}
class Consumer2 implements Runnable
{
private Resource Res;//私有一个Resource对象
Consumer2(Resource Res)//构造函数,传入Resource对象
{
this.Res=Res;
}
public void run()//消费线程所要执行的代码
{
try
{
while(true)
Res.out();//调用消费方法,消费商品
}
catch(Exception e)
{ }
}
} public class LockMethod2
{
public static void main (String[] args)
{
Resource r=new Resource();//创建Resource对象 Consumer2 con=new Consumer2(r);//分别创建生产者消费者对象,并使其指向Resource对象
Producer2 pro=new Producer2(r); Thread t1=new Thread(pro);//创建线程1234,分别指向生产者和消费者。
Thread t2=new Thread(pro);
Thread t3=new Thread(con);
Thread t4=new Thread(con); t1.start();//启动线程
t2.start();
t3.start();
t4.start();
}
}

Lock锁与Condition监视器(生产者与消费者)。的更多相关文章

  1. condition版生产者与消费者模式

    1.简介 在爬虫中,生产者与消费者模式是经常用到的.我能想到的比较好的办法是使用redis或者mongodb数据库构造生产者消费者模型.如果直接起线程进行构造生产者消费者模型,线程容易假死,也难以构造 ...

  2. 用ReentrantLock和Condition实现生产者和消费者模式

    前面一篇文章<wait.notify应用场景(生产者-消费者模式)>是一种生产者消费者模式实现,今晚这是Lock方式实现,下面是源码: 生产者代码: /** * 生产者 * * @auth ...

  3. 20181229(守护进程,互斥锁,IPC,生产者和消费者模型)

    一.守护进程 守护进程:一个进程B守护另一个进程A,当被守护的进程A结束,进程B也就结束了.(不一定同生,但会同死) 两个特点: ①守护进程会在主进程代码执行结束后就终止 ②守护进程内无法再开启子进程 ...

  4. 守护进程,互斥锁,IPC,生产者与消费者模型

    守护进程: b 进程守护 a进程,当a进程执行完毕时,b进程会跟着立马结束 守护进程用途: 如果父进程结束了,子进程无需运行了,就可以将子进程设置为父进程的守护进程 例如我们qq视频聊天时,当我们退出 ...

  5. ReentrantLock和Condition实现生产者和消费者

    一个生产者和一个消费者 public class ConditionTest { private static ReentrantLock lock = new ReentrantLock(); pr ...

  6. (删)Java线程同步实现二:Lock锁和Condition

    在上篇文章(3.Java多线程总结系列:Java的线程同步实现)中,我们介绍了用synchronized关键字实现线程同步.但在Java中还有一种方式可以实现线程同步,那就是Lock锁. 一.同步锁 ...

  7. java 线程 Lock 锁使用Condition实现线程的等待(await)与通知(signal)

    一.Condition 类 在前面我们学习与synchronized锁配合的线程等待(Object.wait)与线程通知(Object.notify),那么对于JDK1.5 的 java.util.c ...

  8. 线程高级篇-Lock锁和Condition条件

    浅谈Synchronized: synchronized是Java的一个关键字,也就是Java语言内置的特性,如果一个代码块被synchronized修饰了,当一个线程获取了对应的锁,执行代码块时,其 ...

  9. java使用lock实现一个简单的生产者和消费者模式

    import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.ReentrantLock; public ...

随机推荐

  1. vue 中样式的绑定

    1.class的对象绑定 //对应的css <style> .active { color: red; } </style> <!--html 对应的代码--> & ...

  2. C++ LocalAlloc() & LocalSize() & LocalFree ()

    关于LocalAlloc function,参考:https://msdn.microsoft.com/en-us/library/windows/desktop/aa366723(v=vs.85). ...

  3. 如何用TortoiseSVN对文件进行操作

    我们如何用TortoiseSVN修改文件,添加文件,删除文件,以及如何解决冲突等. 添加文件 在检出的工作副本中添加一个Readme.txt文本文件,这时候这个文本文件会显示为没有版本控制的状态,如图 ...

  4. java读取.txt文件工具类FileUtiles

    public class FileUtils { private static final String ENCODING = "UTF-8";//编码方式 /** * 获取文件的 ...

  5. bootstrap-table 刷新页面数据

    bom.bootstrapTable('load',msg['object']);//这一步 务必要添加. if(msg['code']==1){ bom.find('tbody').css('dis ...

  6. Java接口自动化测试之TestNG测试报告ExtentReports的应用(三)

    pom.xml导入包 <?xml version="1.0" encoding="UTF-8"?> <project xmlns=" ...

  7. K/3 Cloud Web API接口说明文

    K/3 Cloud Web API接口说明文 目的 三方集成,提供第三方系统与Cloud集成调用接口. 技术实现 HTTP + Json 提供标准接口 编号 名称 说明 1 Kingdee.BOS.W ...

  8. 记录一次因代理Controller产生的404问题

    spring 3.2.4 为了给每一个controller配置一个拦截器链 import com.google.common.collect.Lists; import org.aopalliance ...

  9. bzoj2683&&bzoj4066

    题解: 前一题不是强制在线,后一题是强制在线 树套树空间会炸 说一下cdq分治+树状数组 首先我们利用cdq分治使得查询和操作保证先后关系 然后矩阵查询变成4个矩阵的差 那么我们就可以运用扫描线的方法 ...

  10. 用groovy脚本进行每日工作的自动化【groovy】

    我们可以用groovy编写日常的批处理脚本,类似windows下的bat或者unix下的shell.其具体的编写方式非常简单,比如我们想要执行一个dir的命令,只要编写一个test.groovy,其中 ...