Spring TaskExecutor 问题

2021-05-20 08:58:55 +08:00
 hello2060

我的 service 想要开启一个线程做计算,

所以我用了

Class MyService() {
    SimpleAsyncTaskExecutor theExecutor = new SimpleAsyncTaskExecutor();
    theExecutor.setConcurrencyLimit(1);

    Runnable indexAll = () -> {
        // do job
    }
    public void doJob() {
        theExecutor.execute(indexAll);
    }
}

但这样的设置是,比如我调用 service.doJob() 10 次,他最终会执行 10 次,一个一个来。我的要求是一旦已经有 job 在执行了,这时候调用 service.doJob() 不会放到队列里去,也就是直接忽略。

请问有这样的设置吗?或者 Spring 有提供任何相关的工具?

谢谢

1007 次点击
所在节点    Java
5 条回复
hello2060
2021-05-20 09:34:29 +08:00
看来有个 bounded thread pool 可以设置超过指定数量以后丢弃,我来试试看
oaix
2021-05-20 09:34:44 +08:00
new ThreadPoolExecutor(
1, // core
1, // max
0, // alive
TimeUnit.SECONDS,
new SynchronousQueue<>(),
new RejectedExecutionHandler() {
@Override
public void rejectedExecution(Runnable r, ThreadPoolExecutor executor) {
// ignore
}
}
);
reeco
2021-05-20 10:05:51 +08:00
加个锁不就好了吗
ailaoli
2021-05-20 10:13:22 +08:00
CountDownLatch ?
hello2060
2021-05-20 10:30:57 +08:00
@oaix 这个可以的,

.execute() 如果已经有 job 在运行会抛出 RejectedExecutionException, 完美。谢啦

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/778034

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX