代码如下:
public class StartApplication {
public static void main(String[] args) {
PrintDemo printDemo = new PrintDemo();
Thread t1 = new Thread(printDemo);
Thread t2 = new Thread(printDemo);
t1.setName("甲");
t2.setName("乙");
t1.start();
t2.start();
}
}
//交叉打印1-100的数
class PrintDemo implements Runnable {
private int number = 1;
@Override
public void run() {
while (true) {
synchronized (this) {
notifyAll();
if (number <= 100) {
try {
Thread.sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + ":" + number);
number++;
try {
wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
} else {
break;
}
}
}
}
}
结果如下:
甲:1
乙:2
甲:3
乙:4
甲:5
乙:6
甲:7
乙:8
甲:9
乙:10
甲:11
乙:12
甲:13
乙:14
甲:15
乙:16
甲:17
乙:18
甲:19
乙:20
甲:21
乙:22
甲:23
乙:24
甲:25
乙:26
甲:27
乙:28
甲:29
乙:30
甲:31
乙:32
甲:33
乙:34
甲:35
乙:36
甲:37
乙:38
甲:39
乙:40
甲:41
乙:42
甲:43
乙:44
甲:45
乙:46
甲:47
乙:48
甲:49
乙:50
甲:51
乙:52
甲:53
乙:54
甲:55
乙:56
甲:57
乙:58
甲:59
乙:60
甲:61
乙:62
甲:63
乙:64
甲:65
乙:66
甲:67
乙:68
甲:69
乙:70
甲:71
乙:72
甲:73
乙:74
甲:75
乙:76
甲:77
乙:78
甲:79
乙:80
甲:81
乙:82
甲:83
乙:84
甲:85
乙:86
甲:87
乙:88
甲:89
乙:90
甲:91
乙:92
甲:93
乙:94
甲:95
乙:96
甲:97
乙:98
甲:99
乙:100
总结:
说明:
涉及到的三个方法:
wait():一旦执行此方法,当前线程就进入阻塞状态,并释放同步监视器。
notify():一旦执行此方法,就会唤醒被wait的一个线程。如果有多个线程被wait,就唤醒优先级高的那个
notifyAll():一旦执行此方法,就会唤醒所有被wait的线程。
1.wait(),notify(),notifyAll()三个方法必须使用在同步代码块或同步方法中。
2.wait(), notify() , notifyAll()三个方法的调用者必须是同步代码块或同步方法中的同步监视器
否则,会出现工IllegalMonitorStateException异常。
3.wait( ),notify(), notifyAll()三个方法是定义在java.lang.Object类中。
面试题: sleep()和wait()的异同?
1.相同点:一旦执行方法,都可以使得当前的线程进入阻塞状态。
2.不同点:
1)两个方法声明的位置不同:Thread类中声明sleep() , object类中声明wait()
2)调用的要求不同: sleep()可以在任何需要的场景下调用。wait()必须使用在同步代码块或者同步方法中
3)关于是否释放同步监视器:如果两个方法都使用在同步代码块或同步方法中,sleep()不会释放锁,wait()会释放锁
这是一个Java编程示例,展示了如何使用多线程交叉打印1到100的数字。主要涉及wait()、notify()和notifyAll()方法的使用,以及线程同步的概念。代码创建了两个线程,它们交替打印数字,直至完成1-100的序列。同步监视器是PrintDemo类的实例,wait()方法用于线程等待,notify()和notifyAll()用于唤醒等待的线程。
299

被折叠的 条评论
为什么被折叠?



