1 package multithread4;
2
3 /*
4 * 生产者,消费者。
5 *
6 * 多生产者,多消费者的问题。
7 *
8 * if判断标记,只有一次,会导致不该运行的线程运行了。出现了数据错误的情况。
9 * while判断标记,解决了线程获取执行权后,是否要运行!
10 *
11 * notify:只能唤醒一个线程,如果本方唤醒了本方,没有意义。而且while判断标记+notify会产生死锁
12 * notifyAll解决了,本方线程一定会唤醒对方线程
13 *
14 * 死锁 四个线程都等待没有被唤醒也是一种情况,悬挂
15 */
16
17 class Resource2{
18 private String name;
19 private int count = 1;
20 private boolean flag = false;
21 public synchronized void set(String name) {
22
23 /*if*/ while (flag) {
24 try {
25 this.wait();
26 } catch (InterruptedException e) {
27
28 }
29 }
30 this.name = name + count;
31 count++;
32 System.out.println(Thread.currentThread().getName()+"..生产者.."+this.name);
33 flag = true;
34 // notify();
35 notifyAll();
36 }
37 public synchronized void out() {
38 /*if*/ while (!flag) {
39 try {
40 this.wait();
41 } catch (InterruptedException e) {
42
43 }
44 }
45 System.out.println(Thread.currentThread().getName()+"..消费者......"+this.name);
46 flag = false;
47 // notify();
48 notifyAll();//为了解决死锁 将其余三个都唤醒
49 }
50 }
51
52 class Producer implements Runnable{
53 private Resource2 r;
54 public Producer(Resource2 r) {
55 this.r = r;
56 }
57 public void run() {
58 while(true) {
59 r.set("烤鸭");
60 }
61 }
62 }
63 class Consumer implements Runnable{
64 private Resource2 r;
65 public Consumer(Resource2 r) {
66 this.r = r;
67 }
68 public void run() {
69 while(true) {
70 r.out();
71 }
72 }
73 }
74 public class ProducerConsumerDemo {
75
76 public static void main(String[] args) {
77
78 Resource2 r = new Resource2();
79 Producer pro = new Producer(r);
80 Consumer con = new Consumer(r);
81
82 Thread t0 = new Thread(pro);
83 Thread t1 = new Thread(pro);
84 Thread t2 = new Thread(con);
85 Thread t3 = new Thread(con);
86
87 t0.start();
88 t1.start();
89 t2.start();
90 t3.start();
91 }
92
93 }

ProducerConsumerDemo

多线程-线程间通信-多生产者多消费者问题解决(notifyAll)的更多相关文章

  1. 多线程-线程间通信-多生产者多消费者问题(JDK1.5后Lock,Condition解决办法及开发中代码范例)

    1 package multithread4; 2 3 import java.util.concurrent.locks.Condition; 4 import java.util.concurre ...

  2. Java多线程——线程间通信

    Java多线系列文章是Java多线程的详解介绍,对多线程还不熟悉的同学可以先去看一下我的这篇博客Java基础系列3:多线程超详细总结,这篇博客从宏观层面介绍了多线程的整体概况,接下来的几篇文章是对多线 ...

  3. Python多线程,线程死锁及解决,生产者与消费者问题

    1.Thread类 普通调用 t = Thread(target=test, args=(i,)) # test为目标函数名, 若函数需要参数将其以元组形 # 式赋给args, 若无参数可不写 t.s ...

  4. 多线程 线程间通信 wait,notify

    1. 方法wait锁释放,notify()锁不释放

  5. java多线程:线程间通信——生产者消费者模型

    一.背景 && 定义 多线程环境下,只要有并发问题,就要保证数据的安全性,一般指的是通过 synchronized 来进行同步. 另一个问题是,多个线程之间如何协作呢? 我们看一个仓库 ...

  6. linux 信号量sem实现 生产者—消费者(线程间通信)

    #include<pthread.h> #include<stdlib.h> #include<stdio.h> #include<unistd.h> ...

  7. java多线程与线程间通信

    转自(http://blog.csdn.net/jerrying0203/article/details/45563947) 本文学习并总结java多线程与线程间通信的原理和方法,内容涉及java线程 ...

  8. Java——多线程之线程间通信

    Java多线系列文章是Java多线程的详解介绍,对多线程还不熟悉的同学可以先去看一下我的这篇博客Java基础系列3:多线程超详细总结,这篇博客从宏观层面介绍了多线程的整体概况,接下来的几篇文章是对多线 ...

  9. Java多线程编程(6)--线程间通信(下)

      因为本文的内容大部分是以生产者/消费者模式来进行讲解和举例的,所以在开始学习本文介绍的几种线程间的通信方式之前,我们先来熟悉一下生产者/消费者模式.   在实际的软件开发过程中,经常会碰到如下场景 ...

随机推荐

  1. SpringBoot 上传文件功能

    注意事项: springboot默认有以下文件配置要求, 可以自行在配置文件里面修改 spring: servlet: multipart: enabled: true #是否处理上传 max-fil ...

  2. JAVA字符串拼接操作规则说明

    1.常量与常量的拼接结果在常量池,原理是编译期优化 public void test1() { String s1 = "a" + "b" + "c& ...

  3. Once Again...

    Once Again... 题目链接 题意 给n个数,然后T次循环后组成一个新的数列,求这个数列的最长不递减子序列. 思路 因为最多就100个元素,所以当m<=100的时候直接暴力求最长不递减子 ...

  4. [opencv]利用minAreaRect计算平面矩形的旋转角度

    #include "opencv2/core/core.hpp" #include "opencv2/highgui/highgui.hpp" #include ...

  5. Android程序设计基础作业目录 (作业笔记)

    Android程序设计基础 • [目录] 第1章 Android程序入门 >>> 1.2.4 安装并配置 Android Studio 开发工具和 Genymotion 模拟器. 1 ...

  6. Eclipse远程调试Java代码的三种方法

    Eclipse远程调试Java代码的三种方法, 第1种方法是用来调试已经启动的Java程序,Eclipse可以随时连接到远程Java程序进行调试, 第2种方法可以调试Java程序启动过程,但是Ecli ...

  7. centOS8安装java14

    一.去官网下载相应的linux版本 二.通过xftp把下载下的文件传输到linux下指定目录 三.使用命令 rpm -ivh 安装(tar.gz 使用 tar zxvf 命令) 四.配置环境变量   ...

  8. Java定时调度

    一.实现方式 Timer:单线程,串行: ScheduledExecutor:并行,论询,实现麻烦: Spring Scheduler:适合小任务: JcronTab:按照crontab语法编写的ja ...

  9. 深入了解mysql--gap locks,Next-Key Locks

    Next-Key Locks Next-Key Locks是在存储引擎innodb.事务级别在可重复读的情况下使用的数据库锁,官网上有介绍,Next-Key Locks是行锁和gap锁的组合.行锁是什 ...

  10. LINUX学习--nginx服务器的安装

    一.安装环境 操作系统CentOS6.8 关闭SeLinux和iptables防火墙 二.网络yum源 将下面的软件下载到  /etc/yum.repos.d/   的目录下 官方基础:http:// ...