From 04a4d347bdd279be3281bf769de84e516b27000e Mon Sep 17 00:00:00 2001 From: Erik Gahlin Date: Wed, 16 Nov 2022 20:01:37 +0000 Subject: [PATCH] 8297006: JFR: AbstractEventStream should not hold thread instance Reviewed-by: mgronlun --- .../jdk/jfr/internal/consumer/AbstractEventStream.java | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/consumer/AbstractEventStream.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/consumer/AbstractEventStream.java index d01a05154d0..130cce21dd6 100644 --- a/src/jdk.jfr/share/classes/jdk/jfr/internal/consumer/AbstractEventStream.java +++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/consumer/AbstractEventStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2019, 2021, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2019, 2022, 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 @@ -62,7 +62,6 @@ public abstract class AbstractEventStream implements EventStream { private final StreamConfiguration streamConfiguration = new StreamConfiguration(); private final List configurations; private final ParserState parserState = new ParserState(); - private volatile Thread thread; private Dispatcher dispatcher; private boolean daemon = false; @@ -214,14 +213,13 @@ public abstract class AbstractEventStream implements EventStream { public final void startAsync(long startNanos) { startInternal(startNanos); Runnable r = () -> run(accessControllerContext); - thread = SecuritySupport.createThreadWitNoPermissions(nextThreadName(), r); + Thread thread = SecuritySupport.createThreadWitNoPermissions(nextThreadName(), r); SecuritySupport.setDaemonThread(thread, daemon); thread.start(); } public final void start(long startNanos) { startInternal(startNanos); - thread = Thread.currentThread(); run(accessControllerContext); }