package 多线程;
class Producer implements Runnable{
private Data data;
public Producer(Data data){
this.data=data;
}
@Override
public synchronized void run() {
for(int i=0;i<50;i++){
if(i%2==0){
this.data.setTitle("饼干");
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
this.data.setValue("麦香饼干");
}else{
this.data.setTitle("饮料");
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
this.data.setValue("果汁好喝");
}
}
}
}
class Consumer implements Runnable{
private Data data;
public Consumer(Data data){
this.data=data;
}
@Override
public synchronized void run() {
for(int i=0;i<50;i++){
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("消费:"+this.data.getTitle()+"->"+this.data.getValue());
}
}
}
class Data{
private String title;
private String value;
public void setTitle(String title) {
this.title = title;
}
public String getTitle() {
return title;
}
public void setValue(String value) {
this.value = value;
}
public String getValue() {
return value;
}
}
public class TestProducerConsumer {
public static void main(String[] args) {
Data data=new Data();
new Thread(new Producer(data)).start();
new Thread(new Consumer(data)).start();
}
}

数据错乱

 package 多线程;
class Producer implements Runnable{
private Data data;
public Producer(Data data){
this.data=data;
}
@Override
public void run() {
for(int i=0;i<50;i++){
if(i%2==0){
this.data.set("饼干","麦香饼干");
}else{
this.data.set("饮料","果汁好喝");
}
}
}
}
class Consumer implements Runnable{
private Data data;
public Consumer(Data data){
this.data=data;
}
@Override
public void run() {
for(int i=0;i<50;i++){
System.out.println("消费:"+this.data.get());
}
}
}
class Data{
private String title;
private String value;
public synchronized void set(String title,String value) {
//若不加synchronized仍会有数据错乱现象
this.title = title;
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
this.value=value;
}
public synchronized String get() {
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
return title+"->"+value;
}
}
public class TestProducerConsumer {
public static void main(String[] args) {
Data data=new Data();
new Thread(new Producer(data)).start();
new Thread(new Consumer(data)).start();
}
}

解决错乱,但有重复现象(非奇偶交替)

 package 多线程;
class Producer implements Runnable{
private Data data;
public Producer(Data data){
this.data=data;
}
@Override
public void run() {
for(int i=0;i<50;i++){
if(i%2==0){
this.data.set("饼干","麦香饼干");
}else{
this.data.set("饮料","果汁好喝");
}
}
}
}
class Consumer implements Runnable{
private Data data;
public Consumer(Data data){
this.data=data;
}
@Override
public void run() {
for(int i=0;i<50;i++){
System.out.println("消费:"+this.data.get());
}
}
}
class Data{
private boolean flag=true;//如果不初始设置为true可能会在第一个消费时取得null
private String title;
private String value;
public synchronized void set(String title,String value) {
if(this.flag==false)
try {
super.wait();
} catch (InterruptedException e1) {
e1.printStackTrace();
}
//若不加synchronized仍会有数据错乱现象
this.title = title;
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
this.value=value;
this.flag=false;
super.notify();
}
public synchronized String get() {
if(this.flag==true)
try {
super.wait();
} catch (InterruptedException e1) {
e1.printStackTrace();
}
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
this.flag=true;
super.notify();
return title+"->"+value;
}
}
public class TestProducerConsumer {
public static void main(String[] args) {
Data data=new Data();
new Thread(new Producer(data)).start();
new Thread(new Consumer(data)).start();
}
}

解决重复问题

【java】多线程同步生产者消费者问题的更多相关文章

  1. Java多线程同步——生产者消费者问题

    这是马士兵老师的Java视频教程里的一个生产者消费者问题的模型 public class ProduceConsumer{ public static void main(String[] args) ...

  2. Java 多线程同步生产者消费者问题-monitor

    对这个问题更深一点理解是,每一个线程都在竞争这个类的实例的monitor对象. java会为每个object对象分配一个monitor,当某个对象的同步方法(synchronized methods ...

  3. java多线程解决生产者消费者问题

    import java.util.ArrayList; import java.util.List; /** * Created by ccc on 16-4-27. */ public class ...

  4. java多线程模拟生产者消费者问题,公司面试常常问的题。。。

    package com.cn.test3; //java多线程模拟生产者消费者问题 //ProducerConsumer是主类,Producer生产者,Consumer消费者,Product产品 // ...

  5. Java多线程_生产者消费者模式2

    在我的上一条博客中,已经介绍到了多线程的经典案列——生产者消费者模式,但是在上篇中用的是传统的麻烦的非阻塞队列实现的.在这篇博客中我将介绍另一种方式就是:用阻塞队列完成生产者消费者模式,可以使用多种阻 ...

  6. JAVA多线程之生产者 消费者模式 妈妈做面包案例

    创建四个类 1.面包类 锅里只可以放10个面包 ---装面包的容器2.厨房 kitchen 生产面包 和消费面包  最多生产100个面包3.生产者4消费者5.测试类 多线程经典案例 import ja ...

  7. 【多线程】java多线程实现生产者消费者模式

    思考问题: 1.为什么用wait()+notify()实现生产者消费者模式? wait()方法可以暂停线程,并释放对象锁 notify()方法可以唤醒需要该对象锁的其他线程,并在执行完后续步骤,到了s ...

  8. Java多线程之生产者消费者问题&lt;一&gt;:使用synchronized keyword解决生产者消费者问题

    今天看了一片博文,讲Java多线程之线程的协作,当中作者用程序实例说明了生产者和消费者问题,但我及其它读者发现程序多跑几次还是会出现死锁,百度搜了下大都数的样例也都存在bug,经过细致研究发现当中的问 ...

  9. Java多线程实现生产者消费者延伸问题

    在操作系统中有一类问题被称为生产者消费者问题:意为,有数个生产者生产产品,有数个消费者消费产品,他们共享一定数量的缓存. 这里用java多线程编程,实现生产者消费者问题的一种延伸,橘子苹果问题. 题目 ...

  10. Java多线程-----实现生产者消费者模式的几种方式

       1 生产者消费者模式概述 生产者消费者模式就是通过一个容器来解决生产者和消费者的强耦合问题.生产者和消费者彼此之间不直接通讯,而通过阻塞队列来进行通讯,所以生产者生产完数据之后不用等待消费者处理 ...

随机推荐

  1. 【JAVA零基础入门系列】Day15 对象的比较

    最近一直有事,博客也停笔了一段时间,十分抱歉. 这一篇主要讲讲对象的比较,什么是对象的比较,我们知道两个数值类型只需要用"=="符号即可进行相等判断,但如果是两个Goods对象呢? ...

  2. 入坑第二式 golang入坑系统

    史前必读: 这是入坑系列的第二式,如果错过了第一式,可以去gitbook( https://andy-zhangtao.gitbooks.io/golang/content/ )点个回放,看个重播.因 ...

  3. setTimeout和setInterval实现滚动轮播中,清除定时器的思考

    PS:希望各路大神能够指点 setTimeout(function,time):单位时间内执行一次函数function,以后不执行:对应清除定时器方法为clearTimeout; setInterva ...

  4. django之第二天

    今天学习目标: 一,路由系统 1,默认处理函数 2,动态URL 3,分级匹配 4,反射实现动态路由 二.中间件 三.Model(重点) 1,创建表 2,操作表数据 四.Form (重点) 1,用户提交 ...

  5. lua lua解读

    1.线程状态宏定义(thread status) #define LUA_OK 0 #define LUA_YIELD 1 #define LUA_ERRRUN 2 #define LUA_ERRSY ...

  6. python学习笔记 函数

    形式: def function(a,b,c=0,*args,**kw)#a,b必选参数,*args可变参数,**kw关键字参数 1.函数的返回值可以是多个参数.多个参数时,实际上返回的是一个tupl ...

  7. 案例学习总结:原生JS实现表格排序

    最近在学习js的表格排序,没想到看不起眼的表格排序实际上却暗含了众多JS知识点.在这里记录一下此次学习过程.希望对大家也有所帮助. 完整的表格排序涉及了下列这些知识点: call方法使用 sort方法 ...

  8. 企业实战Nginx+Tomcat动静分离架构的技术分享

    Nginx动静分离简单来说就是把动态跟静态请求分开,不能理解成只是单纯的把动态页面和静态页面物理分离.严格意义上说应该是动态请求跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat.Re ...

  9. esp8266 SDK开发之编译流程

    最近刚完成自己8266的小项目,已经发布在github上,有兴趣的朋友可以看一下 github地址:esp-ujn 1. 通过MQTT协议与服务器交互 2. 内置HTTP服务器,支持通过浏览器进行参数 ...

  10. 关于websorm卡顿的问题

    要是电脑不卡的话,使用webstorm真可谓是一种享受,但是随着项目的开展,文件逐渐增大,webstorm自然也会出现卡顿(毕竟缺点就是吃内存),这个时候我们可以增加Xms设置 Start1: 1 找 ...