编写多线程程序,模拟多个人通过一个山洞。这个山洞每次只能通过一个人,每个人通过山洞的时间为2秒(sleep)。随机生成10个人,都要通过此山洞,用随机值对应的字符串表示人名,打印输出每次通过山洞的人名。提示:利用线程同步机制,过山洞用一条输出语句表示,该输出语句打印输出当前过山洞的人名,每个人过山洞对应一个线程,哪个线程执行这条输出语句,就表示哪个人过山洞
test1.java
package threadcour;
public class test1 {
static Object clock=new Object();
public static void main(String[] args) {
Tunner tunner=new Tunner(clock);
for(int i=0;i<10;i++){
new Thread(tunner,""+Math.random()*100).start();
}
System.out.println("所有的人都已经到达山洞");
}
}
class Tunner implements Runnable{
private Object clock;
public Tunner(Object clock2) {
this.clock=clock2;
}
@Override
public void run() {
synchronized (clock) {
System.out.println(Thread.currentThread().getName()+"正在过山洞");
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+"过完了");
}
}
}
运行结果:
28.23883774537356正在过山洞
所有的人都已经到达山洞
28.23883774537356过完了
73.64517223481191正在过山洞
73.64517223481191过完了
0.9075187969981302正在过山洞
0.9075187969981302过完了
46.94706784163314正在过山洞
46.94706784163314过完了
36.45865380789073正在过山洞
36.45865380789073过完了
11.617979590450577正在过山洞
11.617979590450577过完了
27.096233959190464正在过山洞
27.096233959190464过完了
67.15721000515788正在过山洞
67.15721000515788过完了
42.08747211807798正在过山洞
42.08747211807798过完了
52.03257164210905正在过山洞
52.03257164210905过完了
总结:
这里为了控制他们,使用static变量来限制并发数量,一个一个的过洞