gpt4 book ai didi

java - 对 Java 线程池感到困惑

转载 作者:行者123 更新时间:2023-11-29 03:23:58 25 4
gpt4 key购买 nike

这是我第一次在我的新项目中使用 Java 线程池,在我遇到这个之后链接http://www.javacodegeeks.com/2013/01/java-thread-pool-example-using-executors-and-threadpoolexecutor.html ,我对此比较困惑,这是页面中的代码,

package com.journaldev.threadpool;

public class WorkerThread implements Runnable {

private String command;

public WorkerThread(String s){
this.command=s;
}

@Override
public void run() {
System.out.println(Thread.currentThread().getName()+' Start. Command = '+command);
processCommand();
System.out.println(Thread.currentThread().getName()+' End.');
}

private void processCommand() {
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}

@Override
public String toString(){
return this.command;
}
}


package com.journaldev.threadpool;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class SimpleThreadPool {

public static void main(String[] args) {
ExecutorService executor = Executors.newFixedThreadPool(5);
for (int i = 0; i < 10; i++) {
Runnable worker = new WorkerThread('' + i);
executor.execute(worker);
}
executor.shutdown();
while (!executor.isTerminated()) {
}
System.out.println('Finished all threads');
}

}

在代码中,创建了一个固定大小的池并创建了 10 个工作线程,对吗?

线程池本应减轻系统的负担,相反,在上面的代码中,我认为除了工作线程之外还创建了池,从而增加了负担。为什么要费心使用线程池?

谁能解释一下?谢谢

我还在 StackOverflow 上阅读了这篇文章 http://stackoverflow.com/questions/19765904/how-threadpool-re-use-threads-and-how-it-works它也没有帮助我。

最佳答案

这令人困惑,因为 Runnable 被命名为 WorkerThread,但它们不扩展 java.lang.Thread,它们只是实现 Runnable 的对象。实现 Runnable 允许您指定需要执行的任务,而无需实例化实际的 Thread 对象。在您的示例中创建的唯一线程是主线程和由执行程序创建的线程。

请注意,即使您更改此代码以使 WorkerThread 扩展 Thread,只要代码不对其调用 start,就不会导致更多线程实际运行。构造一个线程对象涉及一些事情,比如检查安全管理器和初始化线程局部变量,但它实际上并没有在操作系统级别做任何事情来分配线程。就 Executor 而言,它们只是 Runnable,它会使用线程池的线程来执行它们。

关于java - 对 Java 线程池感到困惑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22049289/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com