package cn.chen.threadcommunication;
/*
线程通讯:一个线程完成了自己的任务时,要通知另外一个线程去完成另一个任务。
生产者与消费者
wait(); 等待如果线程执行了wait方法,那么该线程会进入等待的状态,
等待状态下的线程必须要被其他线程调用notify方法才能唤醒。
notify(); 唤醒 唤醒等待线程。
wait与notify方法要注意的事项:
1.wait方法与notify方法是属于Object对象的。
2.wait方法与notify方法必须要同步代码或者是在同步函数中才能使用。
3.wait与notify方法必须要锁对象来调用。
线程安全问题:
* */
class Product{
//产品类
String name;
double price;
boolean flag = false; //产品是否生产的标志
}
class Producer extends Thread{
//生产者
Product p;
public Producer(Product p){
this.p = p;
}
@Override
public void run() {
// TODO Auto-generated method stub
int i =0;
while(true){
synchronized (p) {
if(p.flag == false){
if(i%2 == 0){
p.name = "apple";
p.price = 4000;
}else{
p.name = "hu wei";
p.price = 1999;
}
System.out.println("生产者生产了:"+p.name+"它的价格是:"+p.price);
p.flag = true;
p.notify();
i++;
}else{
try {
p.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
}
}
class Customer extends Thread{
//消费者
Product p;
public Customer(Product p) {
// TODO Auto-generated constructor stub
this.p = p;
}
@Override
public void run() {
// TODO Auto-generated method stub
while(true){
synchronized (p) {
if(p.flag){
//产品已经生产
System.out.println("消费者消费了"+p.name+"价格:"+p.price);
p.flag = false;
p.notify();
}else{
try {
p.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
}
}
public class Demo {
public static void main(String[] args) {
// TODO Auto-generated method stub
Product p = new Product();
Producer per = new Producer(p);
Customer c = new Customer(p);
per.start();
c.start();
}
}
14.4 线程通讯-生产者与消费者
最新推荐文章于 2024-07-08 02:30:00 发布