线程通信demo
package com.senior.multithread;
/**
* 两个进程交替打印1-100之间的数字
* wait()方法:一旦调用该方法,当前线程进入阻塞状态,释放同步监视器。
* notify();//只唤醒一个除当前进程外的处于阻塞状态的其他线程。看谁的优先级高
* notifyAll();//唤醒所有处于阻塞状态的线程
* 注意:
* ·上述三个方法进行线程通信时,必须只能在同步代码块或同步方法中,不能用在Lock中
* ·上述三个方法的调用者,必须是同步代码块或同步方法中的同步监视器。比如都是this.*,或者都是obj.*
* ·上述三个方法都被定义在Object类中
*
* 讨论:sleep方法和wait方法的异同。
* @author eden
* @create projectTest:2021-05-10-22:44
*
*
*/
public class ThreadCommunicate {
public static void main(String[] args) {
Communicate tmp = new Communicate();
Thread th1 = new Thread(tmp);
Thread th2 = new Thread(tmp);
th1.setName("线程一");
th2.setName("线程二");
th1.start();
th2.start();
}
}
class Communicate implements Runnable {
private int num = 1;
@Override
public void run() {
while (true) {
synchronized (this) {
notify();//只唤醒一个除当前进程外的处于阻塞状态的其他线程。看谁的优先级高
//notifyAll();//唤醒所有处于阻塞状态的线程
try {
Thread.sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
}
if (num <= 100) {
System.out.println(Thread.currentThread().getName() + ":" + num);
num++;
//当线程1执行一次之后我们希望将其阻塞,这样线程二才可以进来;如此实现交替打印
try {
wait();//代码如果写到这里的话,会造成两个线程最终都阻塞到这里,因此需要唤醒线程
} catch (InterruptedException e) {
e.printStackTrace();
}
} else {
break;
}
}
}
}
}
讨论:sleep方法和wait方法的异同
同:二者都可使当前线程进入阻塞状态
不同:
- 声明位置不同,sleep方法在Thread类中声明,wait方法在Object类中声明;
2.使用方式不同,sleep()可以在任何需要的场景下使用,wait()只能在同步代码块或同步方法中使用。
3.sleep()不会释放锁,wait()每次调用会释放锁