From b6c2b234ef835f8516514b8e7773af1411e1e6d1 Mon Sep 17 00:00:00 2001
From: Doug Lea
Date: Sat, 10 Feb 2018 09:17:53 -0800
Subject: [PATCH] 8190324: ThreadPoolExecutor should not specify a dependency
on finalization
Reviewed-by: martin, psandoz, alanb, rriggs, dholmes
---
.../util/concurrent/ThreadPoolExecutor.java | 19 ++++++++++++++-----
.../tck/ThreadPoolExecutorSubclassTest.java | 15 +++++++++++++++
2 files changed, 29 insertions(+), 5 deletions(-)
diff --git a/src/java.base/share/classes/java/util/concurrent/ThreadPoolExecutor.java b/src/java.base/share/classes/java/util/concurrent/ThreadPoolExecutor.java
index c502e783537..2c5ea168c64 100644
--- a/src/java.base/share/classes/java/util/concurrent/ThreadPoolExecutor.java
+++ b/src/java.base/share/classes/java/util/concurrent/ThreadPoolExecutor.java
@@ -35,9 +35,6 @@
package java.util.concurrent;
-import java.security.AccessControlContext;
-import java.security.AccessController;
-import java.security.PrivilegedAction;
import java.util.ArrayList;
import java.util.ConcurrentModificationException;
import java.util.HashSet;
@@ -268,8 +265,8 @@ import java.util.concurrent.locks.ReentrantLock;
*
* - A pool that is no longer referenced in a program AND
* has no remaining threads may be reclaimed (garbage collected)
- * without being explicity shutdown. You can configure a pool to allow
- * all unused threads to eventually die by setting appropriate
+ * without being explicitly shutdown. You can configure a pool to
+ * allow all unused threads to eventually die by setting appropriate
* keep-alive times, using a lower bound of zero core threads and/or
* setting {@link #allowCoreThreadTimeOut(boolean)}.
*
@@ -1462,6 +1459,18 @@ public class ThreadPoolExecutor extends AbstractExecutorService {
}
}
+ // Override without "throws Throwable" for compatibility with subclasses
+ // whose finalize method invokes super.finalize() (as is recommended).
+ // Before JDK 11, finalize() had a non-empty method body.
+
+ /**
+ * @implNote Previous versions of this class had a finalize method
+ * that shut down this executor, but in this version, finalize
+ * does nothing.
+ */
+ @Deprecated(since="9")
+ protected void finalize() {}
+
/**
* Sets the thread factory used to create new threads.
*
diff --git a/test/jdk/java/util/concurrent/tck/ThreadPoolExecutorSubclassTest.java b/test/jdk/java/util/concurrent/tck/ThreadPoolExecutorSubclassTest.java
index 74c8abdee4f..b76c8fb99c5 100644
--- a/test/jdk/java/util/concurrent/tck/ThreadPoolExecutorSubclassTest.java
+++ b/test/jdk/java/util/concurrent/tck/ThreadPoolExecutorSubclassTest.java
@@ -1994,4 +1994,19 @@ public class ThreadPoolExecutorSubclassTest extends JSR166TestCase {
}
}
+ public void testFinalizeMethodCallsSuperFinalize() {
+ new CustomTPE(1, 1,
+ LONG_DELAY_MS, MILLISECONDS,
+ new LinkedBlockingQueue()) {
+
+ /**
+ * A finalize method without "throws Throwable", that
+ * calls super.finalize().
+ */
+ protected void finalize() {
+ super.finalize();
+ }
+ }.shutdown();
+ }
+
}