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(); + } + }