我的问题有点复杂。让我试着彻底解释一下,但是如果你需要更多的细节,请随时问我,我会添加它们。
我最近(通过实验)了解到,如果一个线程持续工作,就像一个while(true)循环中的整数运算,中断线程对它没有影响。线程继续发生,没有发生任何事情。
现在,使用shutDown()或shutDownNow()方法杀死ThreadPoolExecutors。我检查了这些方法的代码,他们使用interrupt()调用来杀死一个线程。所以,如果所有线程都在忙着做什么,那么执行者怎么会被杀?它是如何被杀死的,例如我们在春季应用程序中使用它时。
一个这样的执行者看起来像:
import java.io.File;
import java.io.IOException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Test {
public static void main(String[] a) {
ExecutorService ex = Executors.newFixedThreadPool(50);
for (int i = 0; i < 50; i++) {
ex.execute(new Thread() {
public void run() {
try {
File f = File.createTempFile("testfile", "txt");
while (true) {
f.canRead();
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
}
}
});
}
ex.shutdown();
ex.shutdownNow();
}
}
答案 0 :(得分:5)
要回答你的主要问题,除非明确告知JVM通过System.exit()
退出,否则不会这样做。
对于应该可中断的长时间运行操作,实现的责任是通过Thread.currentThread().isInterrupted()
检查中断标志。
例如:
import java.io.File;
import java.io.IOException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Test {
public static void main(String[] a) {
ExecutorService ex = Executors.newFixedThreadPool(50);
for (int i = 0; i < 50; i++) {
ex.execute(new Runnable() {
public void run() {
try {
File f = File.createTempFile("testfile", "txt");
while (!Thread.currentThread().isInterrupted()) {
f.canRead();
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
}
}
});
}
ex.shutdown();
ex.shutdownNow();
}
}
另请注意,创建Thread
的实例仅用作Runnable
是不合适的。这样做会产生一种间接性,可能会让更多天真的程序员感到困惑。
答案 1 :(得分:0)
你的代码中不应该有无限循环。
线程池不会等待线程退出。
线程将永远运行,直到JVM退出