申请ID:qinsuy【申请通过】
1、申请ID:qinsuy2、个人邮箱:mohu100@126.com
3、原创技术文章:
我从事的是程序方面的工作,但对破解方面不是很了解,想向各位高手学习一下,特申请账号。
废话不多说,我先复制我以前的一篇文章,望各位不吝指正。
任务调度(四)——ScheduledExecutorService替代Timer,实现多线程任务调度
上篇博文《任务调度(三)——Timer的替代品ScheduledExecutorService简介》已经对ScheduledExecutorService做了简单介绍,其实使用ScheduledExecutorService来替代Timer也是迫不得已的事情。主要原因如下:
[*]Timer不支持多线程,所有挂在Timer下的任务都是单线程的,任务只能串行执行,如果其中一个任务执行时间过长,会影响到其他任务的执行,然后就可能会有各种接踵而来的问题。
[*]Timer的线程不捕获异常,TimerTask如果抛出异常,那么Timer唯一的进程就会挂掉,这样挂在Timer下的所有任务都会无法继续执行。
第一个问题,随着业务数据的猛增,我们生产上有几个任务现在每次执行需要1-3个小时,在这段时间内,该timer下的其他任务只能等待,这是让人无法忍受的。重开一个Timer?难道要为所有的耗时的Task都单开一个Timer,显然是不太可能,这样就太乱了。
第二个问题,是极其致命的。好多业务数据都是晚上的定时任务跑出来的,结果由于程序的问题或者内存资源不足,导致线程被kill了。该timer下的所有任务都未执行,结果第二天整整忙活了一天,主要任务就是——跑任务,调整数据。深受其害呀!
为了弥补Timer的缺陷,jdk1.5中引入了并发包,这里面提供的ScheduledExecutorService。具体实现类是:ScheduledThreadPoolExecutor。ScheduledThreadPoolExecutor支持多线程,同时在线程中对异常进行了捕获。所以是Timer的完美替换者。
分享一个实例吧:
测试代码:
执行结果如图:
这样任务之间就不会相互影响了,而且可以同时执行。但是线程数量要设置好了。过渡增加线程数也会适得其反。
这是我最近写的一篇文章,文章地址:http://blog.csdn.net/xiaoxian8023/article/details/47335659
我在CSDN上现在有4个专栏,原创文章170+,访问总量近50W,排名500+
这是我的CSDN网址:http://blog.csdn.net/xiaoxian8023?viewmode=contents
附登陆后的管理界面
希望版主能给通过验证。
ID:qinsuy
邮箱:mohu100@126.com
申请通过,欢迎光临吾爱破解论坛,期待吾爱破解有你更加精彩,ID和密码自己通过邮件密码找回功能修改,请即时登陆并修改密码!
登陆后请在一周内在此帖报道,否则将删除ID信息。 qinsuy前来报道 870079269 发表于 2015-9-26 17:25
@qinsuy
怎么了? @Hmily俺报道了。 恭喜 哈哈 祝贺新人哦。
页:
[1]