package com.bupt.exer;
/**
* 通信样例,两个线程交替打印1-100的数字
*涉及到的方法
* wait(),一旦执行此方法,当前线程就会进入阻塞状态,并释放同步监视器
* notify(),一旦执行此方法,就会唤醒被wait的一个线程,如果有多个线程被wait,就会唤醒优先级高得那个
* notifyAll(),一旦执行此方法,就会唤醒被wait所有的线程
* 说明:
* 1、wait,notify,notifyAll,三个方法只能使用在同步代码块或同步方法中
* 2、wait,notify,notifyAll,三个方法调用者只能使用在同步代码块或同步方法中得同步监视器
* 3、这三个方法定义在java.lang.Object中
* sleep()和wait()的异同?
* 1、相同:一旦执行方法,都可以使得当前线程进入阻塞状态
* 2、不同:1)两个方法声明的位置不同:Thread类中声明sleep()方法,Object类中声明wait()方法
* 2)调用范围不同:sleep()方法可以在任何需要场景下调用
* wait()方法必须使用在同步代码块或者同步方法中
* 3)关于是否释放同步监视器,如果两个方法都在同步代码块或者同步方法中,sleep不会释放,wait会释放
*/
*/
class Number implements Runnable{
private int number = 1;
@Override
public void run() {
while (true) {
synchronized (this) {
notify();
if (number <= 100) {
System.out.println(Thread.currentThread().getName() + ":" + number);
number++;
try {
//使得调用wait()方法的进程进入阻塞状态
wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
} else {
break;
}
}
}
}
}
public class communicationTest {
public static void main(String[] args) {
Number number = new Number();
Thread t1 = new Thread(number);
Thread t2 = new Thread(number);
Thread t3 = new Thread(number);
t1.setName("a");
t2.setName("b");
t1.start();
t2.start();
}
}
package com.bupt.exer;
/**
*线程通信应用:消费者生产者问题
* 分析:
* 1、是否是多线程问题?是,生产者线程,消费者线程
* 2、是否共享数据?是,店员(或产品)
* 3、如何解决线程的安全问题?同步机制,有三种方法
* 4、是否涉及线程通信?是
*/
class Clerk{
private int productCount = 0;
//生产产品
public synchronized void produceProduct() {
if( productCount < 20){
productCount++;
System.out.println(Thread.currentThread().getName()+"开始生产第几"+productCount+"个产品");
notify();
}
else{
try {
wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
//消费产品
public synchronized void consumeProduct() {
if(productCount > 0){
System.out.println(Thread.currentThread().getName()+"开始消费第几"+productCount+"个产品");
productCount--;
notify();
}
else{
try {
wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
class Producer extends Thread{
private Clerk clerk;
public Producer(Clerk clerk){
this.clerk = clerk;
}
@Override
public void run() {
try {
Thread.sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(getName()+" start product....");
while (true){
clerk.produceProduct();
}
}
}
class Consumer extends Thread{
private Clerk clerk;
public Consumer(Clerk clerk){
this.clerk = clerk;
}
@Override
public void run() {
try {
Thread.sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(getName()+" start consumer....");
while (true){
clerk.consumeProduct();
}
}
}
public class ProductTest {
public static void main(String[] args) {
Clerk clerk = new Clerk();
Producer p1 = new Producer(clerk);
p1.setName("p1");
Consumer c1 = new Consumer(clerk);
c1.setName("c1");
p1.start();
c1.start();
}
}