题目:多线程模拟赛马,要求同时起跑,记录每匹马赛跑过程时间,先到达的马需要等后到达的马,在进行下一次赛马。
之前遇到的面试题,当时没做出来,下来又做了一下,感觉还是差点。
public class Play {
public static void main(String[] args){
CountDownLatch countDownLatch = new CountDownLatch(1);
CyclicBarrier cyclicBarrier = new CyclicBarrier(5,()-> System.out.println("全部到达------------"));
for (int i = 0; i < 5; i++) {
new Thread(()->{
try {
countDownLatch.await();//countDownLatch!=0,阻塞
} catch (InterruptedException e) { e.printStackTrace(); }
while(true){
long t1 = System.currentTimeMillis();
System.out.println(Thread.currentThread().getName() + "\t 起跑时间:" + t1);
try {
Thread.sleep(new Random().nextInt(5000));//模拟赛马花费时间
System.out.println(Thread.currentThread().getName() + "\t 到达时间:" + System.currentTimeMillis() + "\t消耗时间" + (System.currentTimeMillis()-t1)+"毫秒");
cyclicBarrier.await();//每个线程执行完+1,加到5,全部放行
} catch (BrokenBarrierException | InterruptedException e) { e.printStackTrace(); }
} },"马"+i).start();
}
countDownLatch.countDown();//countDownLatch-1,减到0,放行
}
}
执行结果