题目
线程1:路人ovtu_1已通过山洞
线程9:路人jsql_9正在通过山洞
线程9:路人jsql_9已通过山洞
线程7:路人ztel_7正在通过山洞
线程7:路人ztel_7已通过山洞
线程5:路人oamk_5正在通过山洞
线程5:路人oamk_5已通过山洞
线程10:路人xjbz_10正在通过山洞
线程10:路人xjbz_10已通过山洞
线程8:路人nkea_8正在通过山洞
线程8:路人nkea_8已通过山洞
线程6:路人wkis_6正在通过山洞
线程6:路人wkis_6已通过山洞
线程4:路人udsz_4正在通过山洞
线程4:路人udsz_4已通过山洞
线程2:路人xrtc_2正在通过山洞
线程2:路人xrtc_2已通过山洞
线程3:路人lpor_3正在通过山洞
线程3:路人lpor_3已通过山洞
编写多线程程序,模拟多个人通过一个山洞。这个山洞每次只能通过一个人,每个人通过山洞的时间为2秒(sleep)。随机生成10个人,都要通过此山洞,用随机值对应的字符串表示人名,打印输出每次通过山洞的人名。提示:利用线程同步机制,过山洞用一条输出语句表示,该输出语句打印输出当前过山洞的人名,每个人过山洞对应一个线程,哪个线程执行这条输出语句,就表示哪个人过山洞。
package cn.ganggang;
import java.util.Random;
public class TestMain {
public static void main(String[] args) {
MyRunnable ru = new MyRunnable();
Random r = new Random();
String str = "abcdefghijklmnopqrstuvwxyz";
for(int i = 1;i<=10;i++){
String itemStr = "" + str.charAt(r.nextInt(str.length()))
+ str.charAt(r.nextInt(str.length()))
+ str.charAt(r.nextInt(str.length()))
+ str.charAt(r.nextInt(str.length())) + "_" + i;// 随机生成四个字母加索引
Thread t = new Thread(ru);
t.setName("线程"+i+":路人"+itemStr);
t.start();
}
}
}
class MyRunnable implements Runnable {
private Object lock = new Object();
@Override
public void run() {
synchronized (lock) {
System.out.println(Thread.currentThread().getName()+"正在通过山洞");
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+"已通过山洞");
}
}
}
运行结果:
线程1:路人ovtu_1正在通过山洞线程1:路人ovtu_1已通过山洞
线程9:路人jsql_9正在通过山洞
线程9:路人jsql_9已通过山洞
线程7:路人ztel_7正在通过山洞
线程7:路人ztel_7已通过山洞
线程5:路人oamk_5正在通过山洞
线程5:路人oamk_5已通过山洞
线程10:路人xjbz_10正在通过山洞
线程10:路人xjbz_10已通过山洞
线程8:路人nkea_8正在通过山洞
线程8:路人nkea_8已通过山洞
线程6:路人wkis_6正在通过山洞
线程6:路人wkis_6已通过山洞
线程4:路人udsz_4正在通过山洞
线程4:路人udsz_4已通过山洞
线程2:路人xrtc_2正在通过山洞
线程2:路人xrtc_2已通过山洞
线程3:路人lpor_3正在通过山洞
线程3:路人lpor_3已通过山洞