From 7c5c5acb6e0954b55a3be10beccd2facb79d9ef8 Mon Sep 17 00:00:00 2001 From: Martin Buchholz Date: Tue, 10 Apr 2018 10:17:35 -0700 Subject: [PATCH] 8201327: Make Sensor deeply immutably thread safe Reviewed-by: alanb, chegar, asmundak --- .../classes/sun/management/MemoryPoolImpl.java | 16 +++++++--------- .../share/classes/sun/management/Sensor.java | 11 ++++------- 2 files changed, 11 insertions(+), 16 deletions(-) diff --git a/src/java.management/share/classes/sun/management/MemoryPoolImpl.java b/src/java.management/share/classes/sun/management/MemoryPoolImpl.java index 881207ae63e..227d19947db 100644 --- a/src/java.management/share/classes/sun/management/MemoryPoolImpl.java +++ b/src/java.management/share/classes/sun/management/MemoryPoolImpl.java @@ -55,10 +55,10 @@ class MemoryPoolImpl implements MemoryPoolMXBean { private long usageThreshold; private long collectionThreshold; - private boolean usageSensorRegistered; - private boolean gcSensorRegistered; - private Sensor usageSensor; - private Sensor gcSensor; + private boolean usageSensorRegistered; // VM-initialized to false + private boolean gcSensorRegistered; // VM-initialized to false + private final Sensor usageSensor; + private final Sensor gcSensor; MemoryPoolImpl(String name, boolean isHeap, long usageThreshold, long gcThreshold) { @@ -72,8 +72,6 @@ class MemoryPoolImpl implements MemoryPoolMXBean { this.collectionThresholdSupported = (gcThreshold >= 0); this.usageSensor = new PoolSensor(this, name + " usage sensor"); this.gcSensor = new CollectionSensor(this, name + " collection sensor"); - this.usageSensorRegistered = false; - this.gcSensorRegistered = false; } public String getName() { @@ -290,7 +288,7 @@ class MemoryPoolImpl implements MemoryPoolMXBean { * unless the memory usage has returned below the threshold. */ class PoolSensor extends Sensor { - MemoryPoolImpl pool; + final MemoryPoolImpl pool; PoolSensor(MemoryPoolImpl pool, String name) { super(name); @@ -316,10 +314,10 @@ class MemoryPoolImpl implements MemoryPoolMXBean { * when the memory usage of a memory pool after GC is crossing * the collection threshold. * The VM will trigger this sensor in subsequent crossing - * regardless if the memory usage has changed siince the previous GC. + * regardless if the memory usage has changed since the previous GC. */ class CollectionSensor extends Sensor { - MemoryPoolImpl pool; + final MemoryPoolImpl pool; CollectionSensor(MemoryPoolImpl pool, String name) { super(name); this.pool = pool; diff --git a/src/java.management/share/classes/sun/management/Sensor.java b/src/java.management/share/classes/sun/management/Sensor.java index c2da61d174c..58a7e5142df 100644 --- a/src/java.management/share/classes/sun/management/Sensor.java +++ b/src/java.management/share/classes/sun/management/Sensor.java @@ -48,10 +48,10 @@ import java.util.HashMap; */ public abstract class Sensor { - private Object lock; - private String name; - private long count; - private boolean on; + private final Object lock = new Object(); + private final String name; + private long count; // VM-initialized to 0 + private boolean on; // VM-initialized to false /** * Constructs a {@code Sensor} object. @@ -60,9 +60,6 @@ public abstract class Sensor { */ public Sensor(String name) { this.name = name; - this.count = 0; - this.on = false; - this.lock = new Object(); } /**