之前不了解多线程的时候,工作中完成业务功能处理,都是按顺序一条一条的执行,哈哈哈,是不是很多小伙伴都有相同的经历啊,哎,都怪当初学得太少,啥也不懂,没有想到还有其它办法可以提高问题的处理效率,那是什么方法呢?相信各位都已经猜到了,那就是多线程,但今天咱们这里不是讲怎么实现多线程,前面已经有文章已经介绍过了,今天要讲的是另一个问题,请各位看官继续往下看。
写一个测试程序,用多个线程打印10000以内的奇数,然后计算消耗的时间和:
public class TestCountDownLatch {
public static void main(String[] args) {
LatchDemo ld = new LatchDemo();
long start = System.currentTimeMillis();
for (int i = 0; i < 3; i++) {
new Thread(ld).start();
}
long end = System.currentTimeMillis();
System.out.println("耗费时间为:" + (end - start));
}
}
class LatchDemo implements Runnable {
@Override
public void run() {
for (int i = 0; i < 10000; i++) {
if (i % 2 != 0) {
System.out.println(i);
}
}
}
}
想法很美好,现实很残酷,结果与想象差得太远,1次为1,1次为0,但这个都不是重点,重点是没有在最后才打印这个耗费时间,按程序执行顺序,应该是多个线程打印奇数,最后再输出消费的时间和
上面的问题有没有办法解决呢?肯定是有的,不要着急,我们现在就来说解决办法,直接上代码:
public class TestCountDownLatch {
public static void main(String[] args) {
CountDownLatch countDownLatch = new CountDownLatch(3);
LatchDemo ld = new LatchDemo(countDownLatch);
long start = System.currentTimeMillis();
for (int i = 0; i < 3; i++) {
new Thread(ld).start();
}
try {
countDownLatch.await();
} catch (InterruptedException e) {
e.printStackTrace();
}
long end = System.currentTimeMillis();
System.out.println("耗费时间为:" + (end - start));
}
}
class LatchDemo implements Runnable {
private CountDownLatch countDownLatch;
LatchDemo(CountDownLatch countDownLatch){
this.countDownLatch = countDownLatch;
}
@Override
public void run() {
try {
for (int i = 0; i < 10000; i++) {
if (i % 2 != 0) {
System.out.println(i);
}
}
} finally {
countDownLatch.countDown();
}
}
}
我们再来看看执行结果:
哈哈哈,搞定,各位看官,通过使用CountDownLatch解决问题,类似于上面测试代码的多个线程计算某类业务指标的场景,都可以使用闭锁来解决哦,希望能帮助到各位。
欢迎各们小伙伴加群交流,期待你们的加入,群号:1077176637