当前位置: 首页 > 知识库问答 >
问题:

如何正确使用Java Executor?

帅颖逸
2023-03-14

我在我的多线程应用程序中使用了Java Executors,但我似乎不知道什么时候使用以下每一种方式是最好的:

ExecutorService executor=Executors.newFixedThreadPool(50);
executor.execute(new A_Runner(... some parameter ...));
executor.shutdown();
while (!executor.isTerminated()) { Thread.sleep(100); }
int Page_Count=200;
ExecutorService executor=Executors.newFixedThreadPool(50);
doneSignal=new CountDownLatch(Page_Count);
for (int i=0;i<Page_Count;i++) executor.execute(new A_Runner(doneSignal, ... some parameter ...));
doneSignal.await();
executor.shutdown();
while (!executor.isTerminated()) { Thread.sleep(100); }
int Executor_Count=30;
ThreadPoolExecutor executor=new ThreadPoolExecutor(Executor_Count,Executor_Count*2,1,TimeUnit.SECONDS,new LinkedBlockingQueue());
List<Future<String>> futures=new ArrayList<>(3330);

for (int i=0;i<50;i++) futures.add(executor.submit(new A_Runner(... some parameter ...));
executor.shutdown();
while (!executor.isTerminated()) { executor.awaitTermination(1,TimeUnit.SECONDS); }
for (Future<String> future : futures)
{
    String f=future.get();
    // ...
}

我想知道的是:这些方法是可以互换的,还是在某种情况下我应该使用上面的特定类型?

共有1个答案

高建本
2023-03-14

>

  • ExecutorService

    ExecutorService Executor=Executors.NewFixedThreadPool(50);

    它简单易用。它隐藏ThreadPoolExecutor的低级详细信息。

    用例:

    >

  • 实现最大并行度:有时我们希望同时启动多个线程以实现最大并行度

    在开始执行之前等待N个线程完成

    ThreadPoolExecutor.DiscardoldestPolicy中,如果未关闭执行器,将删除位于工作队列头部的任务,然后重试执行(可能再次失败,导致重复执行)

    如果要模拟CountDownLatch行为,可以使用InvokeAll()方法。

    您没有引用的另一个机制是ForkJoinPool

      public static ExecutorService newWorkStealingPool()
    

    默认情况下,它将以CPU核心数作为参数。

    这四种机制是相辅相成的。根据您想要控制的粒度级别,您必须选择正确的粒度级别。

  •  类似资料:
    • 问题内容: 我只想检索UserAccount类中的某些列,所以我有以下代码: 我得到了空值作为回报。但是,如果我注释掉setProjections,我将获得具有所有属性的用户。在这种情况下,如何正确使用setProjection? 问题答案: 它返回一个Object数组,因此代码应为:

    • 问题内容: 我不知道我在哪里错了:/。当我运行这段代码时,我得到的只是一个空白元素。我似乎无法让insertRule方法执行任何操作(甚至不会产生错误)。我想念什么吗? 问题答案: 这有点令人困惑,但是您的代码确实可以工作,只是您看不到返回的XML树中插入的规则。 为了验证您的代码是否有效,您可以执行两个测试: 运行上面的代码片段,您可以看到CSS规则确实适用。并且属性也在控制台中更改。 当浏览器

    • 问题内容: 如何使用从类路径中查找递归资源? 例如 在“目录”中查找所有资源:想象一下 不幸的是,这只会检索到恰好该“目录”。 所有资源都已命名(递归) 但这返回一个空。 还有一个额外的问题:与有什么不同? 问题答案: 没有办法递归搜索类路径。您需要知道资源的完整路径名才能以这种方式检索它。该资源可能位于文件系统中的目录中,也可能位于jar文件中,因此它不像执行“类路径”的目录列表那样简单。您将需

    • 问题内容: 我最近开始使用ScriptManager。我有一个通过JavaScript填充的ASP.NET DropDownList控件。但是,我正在使用事件验证。因此,如果我不使用下拉菜单中的“ RegisterForEventValidation”调用,则会遇到以下错误。我怎么知道在第二个参数中设置什么值(我有“值”)?我正在通过JavaScript填充下拉列表,因此我不知道后面的代码中包含哪

    • 我正在尝试正确地使用ByteBuffer和BigEndian字节顺序格式。。 我有几个字段,我试图把它存储在Cassandra数据库之前放在一个单一的ByteBuffer中。 我将要写入Cassandra的字节数组由三个字节数组组成,如下所述- 现在,我将写,和一起到一个字节数组和由此产生的字节数组我将写入Cassandra,然后我将有我的C程序来检索它字节数组数据从Cassandra,然后反序列

    • 问题内容: 我在用 : Node.js Express 4.0 Passport.js Google OAuth 2身份验证 对于每个用户,我将其Google个人资料中的一些信息(电子邮件等…)存储在MySQL数据库中(我对此技术没有选择),访问和刷新令牌以及用户在提供信息时提供的其他信息他在我的应用上注册。 我已经看到了password.js的不同用法,特别是关于该信息在会话中的存储方式。 在p

    • 我有一个分辨率为2560x1920的图像。我正在对它应用精明的操作符。但是我得到的结果不适合我。我希望所有的边缘都突出来。然而,当我将此算法应用于较低分辨率的图像时,一切都正常工作。我怎样才能解决问题?

    • 我尝试使用system.in.read()来获取用户的年龄。我的问题是,如果我写“24”,它会给我输出“你50岁了”。我搜索了一下,发现这和编码有关。所以24映射为50。 有人建议将integer转换为char。所以应该管用。但这一次当我把24,我得到的答案是“你2岁”。 小注:“alter”在德语中是年龄的意思。 我希望有人能帮助我,理解这个问题。如果我能改进什么,请告诉我。不胜感激。