提交 4872c953 编写于 作者: D dbuck

4354680: Runtime.runFinalization() silently clears interrupted flag in the calling thread

Reviewed-by: dholmes, chegar
上级 85f4c97e
...@@ -122,18 +122,18 @@ final class Finalizer extends FinalReference<Object> { /* Package-private; must ...@@ -122,18 +122,18 @@ final class Finalizer extends FinalReference<Object> { /* Package-private; must
AccessController.doPrivileged( AccessController.doPrivileged(
new PrivilegedAction<Void>() { new PrivilegedAction<Void>() {
public Void run() { public Void run() {
ThreadGroup tg = Thread.currentThread().getThreadGroup(); ThreadGroup tg = Thread.currentThread().getThreadGroup();
for (ThreadGroup tgn = tg; for (ThreadGroup tgn = tg;
tgn != null; tgn != null;
tg = tgn, tgn = tg.getParent()); tg = tgn, tgn = tg.getParent());
Thread sft = new Thread(tg, proc, "Secondary finalizer"); Thread sft = new Thread(tg, proc, "Secondary finalizer");
sft.start(); sft.start();
try { try {
sft.join(); sft.join();
} catch (InterruptedException x) { } catch (InterruptedException x) {
/* Ignore */ Thread.currentThread().interrupt();
} }
return null; return null;
}}); }});
} }
...@@ -146,6 +146,7 @@ final class Finalizer extends FinalReference<Object> { /* Package-private; must ...@@ -146,6 +146,7 @@ final class Finalizer extends FinalReference<Object> { /* Package-private; must
forkSecondaryFinalizer(new Runnable() { forkSecondaryFinalizer(new Runnable() {
private volatile boolean running; private volatile boolean running;
public void run() { public void run() {
// in case of recursive call to run()
if (running) if (running)
return; return;
final JavaLangAccess jla = SharedSecrets.getJavaLangAccess(); final JavaLangAccess jla = SharedSecrets.getJavaLangAccess();
...@@ -168,6 +169,7 @@ final class Finalizer extends FinalReference<Object> { /* Package-private; must ...@@ -168,6 +169,7 @@ final class Finalizer extends FinalReference<Object> { /* Package-private; must
forkSecondaryFinalizer(new Runnable() { forkSecondaryFinalizer(new Runnable() {
private volatile boolean running; private volatile boolean running;
public void run() { public void run() {
// in case of recursive call to run()
if (running) if (running)
return; return;
final JavaLangAccess jla = SharedSecrets.getJavaLangAccess(); final JavaLangAccess jla = SharedSecrets.getJavaLangAccess();
...@@ -189,6 +191,7 @@ final class Finalizer extends FinalReference<Object> { /* Package-private; must ...@@ -189,6 +191,7 @@ final class Finalizer extends FinalReference<Object> { /* Package-private; must
super(g, "Finalizer"); super(g, "Finalizer");
} }
public void run() { public void run() {
// in case of recursive call to run()
if (running) if (running)
return; return;
......
/*
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 4354680
* @summary runFinalization() should not clear or ignore interrupt bit
* @run main FinInterrupt
*/
public class FinInterrupt {
public static void main(String[] args) throws Exception {
Thread.currentThread().interrupt();
System.runFinalization();
if (Thread.interrupted()) {
System.out.println("Passed: interrupt bit was still set.");
} else {
throw new AssertionError("interrupt bit was cleared");
}
}
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册