CountDownLatch 压测教程

JAVA herman 316浏览 0评论

在实战项目中,我们除了使用 jemter 等工具进行压测外,还可以自己动手使用 CountDownLatch 类编写压测代码。可以说 jemter 的并发压测背后也是使用的 CountDownLatch。可见掌握 CountDownLatch 类的使用是有多么的重要。

CountDownLatch是Java多线程同步器的四大金刚之一,CountDownLatch能够使一个线程等待其他线程完成各自的工作后再执行。本文介绍 CountDownLatch 的相关用法。

使用CountDownLatch让线程集中执行,代码如下:

private static void latchTest() throws InterruptedException {
	final CountDownLatch start = new CountDownLatch(1);
	final CountDownLatch end = new CountDownLatch(300);
	ExecutorService exce = Executors.newFixedThreadPool(300);
	for (int i = 0; i < 300; i++) {
		Runnable run = new Runnable() {
			@Override
			public void run() {
				try {
					start.await();
					// 测试执行具体的方法
					testLoad();
				} catch (InterruptedException e) {
					e.printStackTrace();
				} finally {
					end.countDown();
				}
			}
		};
		exce.submit(run);
	}
	start.countDown();
	end.await();
	exce.shutdown();
}

简简单单的几行代码就可以实现300的压测。

除了 CountDownLatch 之外,我们还可以使用 java 线程的 join 方法。

join用于让当前执行线程等待join线程执行结束。其实现原理是不停检查join线程是否存活,如果join线程存活则让当前线程永远wait,代码片段如下,wait(0)表示永远等待下去。

while (isAlive()) {
	wait(0);
}

直到join线程中止后,线程的this.notifyAll会被调用,调用notifyAll是在JVM里实现的,所以JDK里看不到,有兴趣的同学可以看看JVM源码。JDK不推荐在线程实例上使用wait,notify和notifyAll方法。

业余草公众号

最后,欢迎关注我的个人微信公众号:业余草(yyucao)!可加QQ1群:135430763(2000人群已满),QQ2群:454796847,QQ3群:187424846。QQ群进群密码:xttblog,想加微信群的朋友,可以微信搜索:xmtxtt,备注:“xttblog”,添加助理微信拉你进群。备注错误不会同意好友申请。再次感谢您的关注!后续有精彩内容会第一时间发给您!原创文章投稿请发送至532009913@qq.com邮箱。商务合作可添加助理微信进行沟通!

本文原文出处:业余草: » CountDownLatch 压测教程