用一场比赛来介绍CyclicBarrier和CountDownLatch区别
cac55 2024-09-19 17:03 26 浏览 0 评论
欢迎关注头条号:老顾聊技术
精品原创技术分享,知识的组装工
目录
- 需求场景
- 分析需求
- 设计思路
- CyclicBarrier
- 终点优化
- 系统耗时
- 起点问题
- CountDownLatch
- 起点优化
- 总结
前言
我们小伙伴们是不是经常需要测试代码的性能?小伙伴们是不是就会想到jmeter进行压力测试一下,模拟N个用户同时执行下,看看响应的时间多少。
今天老顾就用一个经典的比赛案例,来尝试自行编写个比赛业务,并随便介绍一下CyclicBarrier和CountDownLatch区别。 可以根据比赛业务,可以抽象出性能测试工具类。
需求场景
有N个短跑选手进行比赛,希望记录下来整个比赛的时间
1、第一名选手跑完比赛路程所花时间
2、最后一名选手跑完比赛路程所花时间
3、所有选手跑完比赛路程所花时间
4、每个选手跑完比赛路程所花时间之和
上面就是业务需求,那我们如何去实现?
分析需求
先上个图,小伙伴们会更好理解
上图中4个选手在进行赛跑,我们先看一下赛跑规则:
1、每个选手互不干扰,在自己的赛道上面进行跑步
2、选手在跑步前都需要活动一下,做好预备姿势
3、选手是应该在裁判一声枪响下,才能开始跑,不能提前跑
4、每个选手在跑到终点时,裁判会为每个选手记录成绩
5、比赛结束后,大会公布各个选手的成绩,以及排名
设计思路
针对上面的规则,我们需要转换成我们的程序设计:
1、选手间互不干扰,又同时进行赛跑。这个比较简单,肯定用我们的Thread线程去解决。
2、记录时间这个也比较简单,利用System的时钟
我们先到这边,先上代码,创建任务(赛跑)
RunTask代表选手的跑完比赛的耗时,为了真实模拟,加了随机数,表示每个选手的耗时不一样。继续代码,直接在main方法中,进行比赛
上面是一些基础变量,记录耗时。小伙伴要注意要用AtomicLong原子类,避免线程安全问题。下面的代码就是比赛核心逻辑
1、创建线程(选手)
2、执行任务(赛跑)
3、记录成绩(耗时)
一、大会公布成绩
二、执行比赛
小伙伴看看,是不是明显不对啊,总耗时尽然为0,肯定有问题。
应该有人发现了,因为我们是在main方法中执行比赛的,其他线程单独执行,主main线程执行完就终止了程序,而不会管其他线程有没有结束。
这明显和我们想要的不一样,我们需要等所有的选手跑完,才能算比赛结束。那应该怎么优化呢?往下看
CyclicBarrier
我们这里引入一个知识点CyclicBarrier循环屏障,CyclicBarrier是一组线程互相等待,只有全部到达屏障点以后才能继续执行。可以举个生活场景
大巴车进入服务区进行休息,大巴车是要等到所有乘客上车后,才能发车。并不是一个人上车了就可以发车了。这个是所有乘客都知道的规则,互相等待所有人上车,才发车。循环的意思就是大巴车是一直这种规则,可重复利用
我们比赛的例子正好匹配,不是一个选手到达终点(屏障)就比赛结束,而是要等到所有选手到达终点才能结束比赛。
终点优化
根据上面的CyclicBarrier知识点,我们把代码优化一下
一、增加CyclicBarrier变量
//定义屏障,为什么要加1? final CyclicBarrier cb = new CyclicBarrier(nThreads + 1);
为什么要加1?因为比赛裁判肯定先到终点(即主线程),那也需要等待,所以屏障点需要加1。
注意:这个是根据业务来的,如果设置屏障点,是根据业务逻辑设计的
二、选手跑完到屏障点
在选手跑完后,增加到达屏障点,等待
三、裁判到屏障点
这个代码是在main主线程的,也就是裁判会先到,设置屏障点
终点优化结束,执行比赛吧
这个成绩应该没有问题,把大赛的成绩都正确的显示出来了。
系统耗时
我们小伙伴再仔细观察下,上面的成绩:
1、最后一名的耗时3397ms
2、比赛执行完耗时3398ms
相差1ms,当然我们这里设计是以毫秒为单位的,如果以纳秒为单位他们的相差会比1ms少。这个不是关键,关键是其实最后一名跑完,其实就是比赛结束了。按照道理比赛执行耗时和最后一名的耗时是一样的哦。
比赛执行多次,效果都一样相差1ms。这个是为什么呢?就是因为系统耗时,我们看看比赛是在什么时候记时的,是全部选手开跑后才记时的。这边就会存在误差,因为系统执行也会耗时
//上面所有选手都已经开跑了 //整个比赛的开始时间 long startTime = System.currentTimeMillis(); //。。。 //整个比赛的结束时间 long endTime = System.currentTimeMillis();
就是因为系统执行也是会消耗时间的。当然耗时不大就是几纳秒。小伙伴知道这个点后,会不会发现我们整个代码还存在一个问题?
起点问题
我们一场比赛是要等所有选手准备好后,等待裁判发令后,才能开跑。我们来看一下我们的选手开跑代码
选手是通过for循环创建出来的,而且创新好后,就执行start开跑了。这个是不对的。
小伙伴会说for循环很快的,没关系吧。
这里是很有关系的,创建选手耗时是比较长的,而且循环体也有耗时。我们看一下之前的系统耗时,就是获取结束时间也存在系统耗时,何况这里要分配内存、创建对象等。这样对其他选手就不公平了,那怎么办?老顾再分享一个并发控制类CountDownLatch
CountDownLatch
CountDownLatch是一个或一组线程等待其他线程完成各自的工作后再执行。举个例子:
大家考场考试,有人提前交卷,但监考老师是不能走的,因为还有人没有考完,只有等到所有人交卷了,老师才能走。是不是和CyclicBarrier类似,他们也有不同点,自行百度。
到我们这个案例中,应该要等待所有选手准备好后,才能开跑。
起点优化
增加变量,计数器为1,这个值是由我们的设计决定的
//增加CountDownLatch控制类 final CountDownLatch cdl = new CountDownLatch(1);
一、选手预备等待
二、裁判发令
裁判发令后,所有的选手就会立即开跑,利用CountDownLatch达到了控制线程等待,一起执行。再执行比赛看看,也解决了系统耗时误差的问题
-----------大会公布成绩------------- 比赛选手数:4 ------------------------ 所有选手总耗时:6686ms 比赛执行完耗时:1920ms 第一名耗时:1281ms 最后一名耗时:1920ms
总结
这篇文章只是个引子,把并发编程的两个重要的类抛出来,主要介绍应用场景。具体类的用法,小伙伴们可以网上自行学习。还有CyclicBarrier和CountDownLatch两者有相同点,有些场景可以替换使用。当然他们也有不同点,小伙伴们要注重关注。谢谢!!!
小伙伴是不是会说,那个性能测试工具类呢?其实上面已经把90%的核心代码介绍了,把跑步抽象成外部传入的任务,在加入循环执行次数就ok了,小伙伴可以自行完善。如果小伙伴需要,关注、私信、打赏老顾,老顾会把代码链接分享给你。
-End-
如有收获,请帮忙转发,您的鼓励是作者最大的动力,谢谢!
10几年的经验实战分享
相关微服务,分布式,高并发,高可用,企业实战,干货等原创文章正在路上
欢迎关注头条号:老顾聊技术
精品原创技术分享,知识的组装工
推荐阅读
8、分享一线互联网大厂分布式唯一ID设计 之 snowflake方案
12、如何永不迁移数据和避免热点? 根据服务器指标分配数据量(揭秘篇)
13、你知道怎么分库分表吗?如何做到永不迁移数据和避免热点吗?
15、你知道如何更新缓存吗?如何保证缓存和数据库双写一致性?
相关推荐
- 无力吐槽的自动续费(你被自动续费困扰过吗?)
-
今天因为工作需要,需要在百度文库上下载一篇文章。没办法,确实需要也有必要,只能老老实实的按要求买了个VIP。过去在百度文库上有过类似经历,当时为了写论文买了一个月的VIP,后面也没有太注意,直到第二个...
- 百度文库推出“文源计划”创作者可一键认领文档
-
11月7日,百度文库发布了旨在保护创作者权益的“文源计划”。所谓“文源计划”,即为每一篇文档找到源头,让创作者享受更多的权益。据百度文库总经理李小婉介绍,文源计划分为三部分,分别是版权认证、版权扶持和...
- 有开放大学学号的同学,百度文库高校版可以用了。
-
还在网上找百度文库的下载方式,只要从身边的朋友在读开放大学的,那他(她)的学号就可以登陆到国家开放大学图书馆,还使用百度文库高校版来下载。与百度文库稍有不同,但足够使用了。现转国图链接如下:htt...
- 搜索资源方法推荐(搜索资源的方法)
-
今天msgbox就要教大家如何又快又准的搜到各类资源,第一点,排除干扰百度搜索出来啊经常前排展示它的产品以及百度文库,如何去除呢?很简单,后面输入空格减号百度文库,比如你搜高等数学百度文库很多,只要后...
- 一行代码搞定百度文库VIP功能(2021百度文库vip账号密码共享)
-
百度文库作为大家常用查资料找文档的平台,大多数文档我们都可以直接在百度文库找到,然而百度文库也有让人头痛的时候。好不容易找到一篇合适的文档,当你准备复制的时候他却提示你需要开通VIP才能复制~~~下载...
- 百度文库文档批量上传工具用户说明书
-
百度文库文档批量上传工具用户说明书1、软件主要功能1、批量上传文档到百度文库,支持上传到收费、VIP专享、优享以及共享。2、支持自动分类和自动获取标签3、支持多用户切换,一个账户传满可以切换到...
- 百度文库现在都看不到文档是否上传成功,要凉了吗?
-
打开知识店铺,百度文库文档里显示都是下载这一按键,上传的文档也看不到是否成功?咋情况,要取消了吗?没通过审核的也不让你删除,是几个意思,想通吃吗?现在百度上传文档也很费劲,有时弄了半天的资料上传审核过...
- 微信推广引流108式:利用百度文库长期分享软文引流
-
百度文库相对于百度知道、百度百科来说,操作上没那么多条条框框,规则上也相对好把握些。做一条百度知道所花费的精力一般都会比做一条百度文库的要多些,老马个人操作下来觉得百度文库更好把握。但见仁见智吧,今天...
- 职场“避雷”指南 百度文库推出标准化劳动合同范本
-
轰轰烈烈的毕业季结束了,众多应届生在经过了“职场海选”后,已正式成为职场生力军的一员。这一阶段,除了熟悉业务,签订劳动合同、了解职场福利也迅速被提上日程。而随着国人法律意识的增强,百度文库内《劳动合同...
- 《百度文库》:素材精选宝库(百度文库官网首页)
-
《百度文库》:独特功能助力选择高质量素材在当今信息爆炸的时代,如何高效地获取并利用有价值的素材成为了许多人面临的挑战。而《百度文库》作为百度公司推出的一款在线文档分享平台,凭借其丰富的资源、强大的功能...
- 深度整合和开放AI能力 百度文库和网盘推出内容操作系统「沧舟OS」
-
【TechWeb】4月25日消息,Create2025百度AI开发者大会上,百度文库和百度网盘推出全球首个内容操作系统——沧舟OS。基于沧舟OS,百度文库APP全新上线「GenFlow超能搭子」...
- 女子发现大二作业被百度文库要求付费下载,律师:平台侵权,应赔偿
-
近日,28岁的黎女士在百度百科搜索家乡的小地名时,发现了自己在大二完成的课题作业。她继续搜索,发现多个平台收录了该文,比如豆丁网和文档之家等,有的还设置了付费或积分下载。2月15日,九派新闻记者以用户...
- 2016杀入百度文库的新捷径,只有少数人才知道的喔
-
百度的产品在SEO优化中的分量真不用多说,其实很多人都像我一样一直在找捷径。但是我经常发现很多人都是在用死方法。比如发贴吧发帖而不知道去申请一个吧主,知道自问自答而不知道去申请一个合作资格。口碑和贴吧...
- 百度文库付费文档搜索方法(百度文库付费文档搜索方法有哪些)
-
一直以来,百度文库中无论是个人中心还是个人主页,都没有像淘宝一样的店内搜索功能,连最近新开的知识店铺也没有设计店内搜索功能,这无论是对上传用户还是下载用户都不方便,上传用户想要搜索自己的文档无法办到...
- 供读者免费使用!泰达图书馆机构版百度文库新年上新啦
-
在泰达图书馆读者使用百度文库数字资源不需要VIP,免-费-用!惊不惊喜?快来了解一下吧……新年伊始,为满足区域企业、高校、科研院所以及居民群众在教学、科研及学习过程中,对各类文献资源的需求,泰达图书馆...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 如何绘制折线图 (52)
- javaabstract (48)
- 新浪微博头像 (53)
- grub4dos (66)
- s扫描器 (51)
- httpfile dll (48)
- ps实例教程 (55)
- taskmgr (51)
- s spline (61)
- vnc远程控制 (47)
- 数据丢失 (47)
- wbem (57)
- flac文件 (72)
- 网页制作基础教程 (53)
- 镜像文件刻录 (61)
- ug5 0软件免费下载 (78)
- debian下载 (53)
- ubuntu10 04 (60)
- web qq登录 (59)
- 笔记本变成无线路由 (52)
- flash player 11 4 (50)
- 右键菜单清理 (78)
- cuteftp 注册码 (57)
- ospf协议 (53)
- ms17 010 下载 (60)