Skip to content

Commit

Permalink
Merge pull request #679 from tajila/jdknext
Browse files Browse the repository at this point in the history
Clear vmthread from thread object at shutdown
  • Loading branch information
keithc-ca authored Oct 27, 2023
2 parents 025bb49 + 2a71b98 commit 9c8c7f0
Showing 1 changed file with 24 additions and 21 deletions.
45 changes: 24 additions & 21 deletions src/java.base/share/classes/java/lang/Thread.java
Original file line number Diff line number Diff line change
Expand Up @@ -1614,32 +1614,35 @@ void clearReferences() {
* a chance to clean up before it actually exits.
*/
void exit() {
/* Refresh interrupted value so it is accurate when thread reference is removed. */
interrupted = interrupted();

try {
// pop any remaining scopes from the stack, this may block
if (headStackableScopes != null) {
StackableScope.popAll();
}
} finally {
// notify container that thread is exiting
ThreadContainer container = threadContainer();
if (container != null) {
container.onExit(this);
/* Refresh interrupted value so it is accurate when thread reference is removed. */
interrupted = interrupted();

try {
// pop any remaining scopes from the stack, this may block
if (headStackableScopes != null) {
StackableScope.popAll();
}
} finally {
// notify container that thread is exiting
ThreadContainer container = threadContainer();
if (container != null) {
container.onExit(this);
}
}
}

try {
if (threadLocals != null && TerminatingThreadLocal.REGISTRY.isPresent()) {
TerminatingThreadLocal.threadTerminated();
try {
if (threadLocals != null && TerminatingThreadLocal.REGISTRY.isPresent()) {
TerminatingThreadLocal.threadTerminated();
}
} finally {
clearReferences();
}
} finally {
clearReferences();
}
synchronized (interruptLock) {
// so that isAlive() can work
eetop = Thread.NO_REF;
synchronized (interruptLock) {
// so that isAlive() can work
eetop = Thread.NO_REF;
}
}
}

Expand Down

0 comments on commit 9c8c7f0

Please sign in to comment.