我有一jar程序,mainclass里启动了多个timer ,我监测到其中某个timer(设定是24小时执行一次)但是在启动的时候被执行了几百次,其他 的几个timer没有注意到,谁知道这个是怎么回事?或者是某地方有什么问题?long period = 24 * 60 * 60 * 1000;Calendar calendar = Calendar.getInstance();new Timer().scheduleAtFixedRate(new UserTimerTask(), calendar.getTime(), period);
不知道你这个问题是否已经解决, 如果还没有解决的话:就好比一个国企里面有10个(core)正式工的名额,最多招10个正式工,要是任务超过正式工人数(task > core)的情况下,工厂领导(线程池)不是首先扩招工人,还是这10人,但是任务可以稍微积压一下,即先放到队列去(代价低)。10个正式工慢慢干,迟早会干完的,要是任务还在继续增加,超过正式工的加班忍耐极限了(队列满了),就的招临时工帮忙了(注意是临时工)要是正式工加上临时工还是不能完成任务,那新来的任务就会被领导拒绝了(线程池的拒绝策略)。
为啥老板不上来直接招正式工?
首先,招人(new thread)是不是得走流程,办手续,耗时耗力;
其次,要是任务量降低了,养多出来的几个人没活干成本高(维护更多的线程的成本);
最后,要辞退临时工也得各种走流程,各种赔偿,得不偿失。(超时清掉产能过剩的线程的成本)。
正式工(线程)相对于计算机世界,是稀缺资源。国企的铁饭碗可不就是稀缺资源嘛,不到不得已,是不能泛滥的。