From 4e92434bc0e4dc11d070db7ca61b4fdfcae3677b Mon Sep 17 00:00:00 2001 From: Patrick Strawderman Date: Mon, 23 Sep 2024 13:56:56 -0700 Subject: [PATCH] Avoid repeated calls to getState in AbstractDependentConfig The getState method was called repeatedly in various AbstractDependentConfig methods, which could incur repeated volatile reads or correctness issues in edge cases. --- .../config/AbstractDependentConfig.java | 23 ++++++++++++------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/archaius2-core/src/main/java/com/netflix/archaius/config/AbstractDependentConfig.java b/archaius2-core/src/main/java/com/netflix/archaius/config/AbstractDependentConfig.java index e836bbac..ff19aef2 100644 --- a/archaius2-core/src/main/java/com/netflix/archaius/config/AbstractDependentConfig.java +++ b/archaius2-core/src/main/java/com/netflix/archaius/config/AbstractDependentConfig.java @@ -1,5 +1,6 @@ package com.netflix.archaius.config; +import com.netflix.archaius.api.Config; import com.netflix.archaius.api.PropertyDetails; import java.util.Iterator; @@ -27,9 +28,11 @@ public AbstractDependentConfig() { @Override public Object getRawProperty(String key) { - Object value = getState().getData().get(key); - if (getState().getInstrumentedKeys().containsKey(key)) { - getState().getInstrumentedKeys().get(key).recordUsage(createPropertyDetails(key, value)); + CachedState state = getState(); + Object value = state.getData().get(key); + Config config = state.getInstrumentedKeys().get(key); + if (config != null) { + config.recordUsage(createPropertyDetails(key, value)); } return value; } @@ -52,9 +55,11 @@ public Iterable keys() { @Override public void forEachProperty(BiConsumer consumer) { - getState().getData().forEach((k, v) -> { - if (getState().getInstrumentedKeys().containsKey(k)) { - getState().getInstrumentedKeys().get(k).recordUsage(createPropertyDetails(k, v)); + CachedState state = getState(); + state.getData().forEach((k, v) -> { + Config config = state.getInstrumentedKeys().get(k); + if (config != null) { + config.recordUsage(createPropertyDetails(k, v)); } consumer.accept(k, v); }); @@ -77,8 +82,10 @@ public boolean isEmpty() { @Override public void recordUsage(PropertyDetails propertyDetails) { - if (getState().getInstrumentedKeys().containsKey(propertyDetails.getKey())) { - getState().getInstrumentedKeys().get(propertyDetails.getKey()).recordUsage(createPropertyDetails(propertyDetails.getKey(), propertyDetails.getValue())); + CachedState state = getState(); + Config config = state.getInstrumentedKeys().get(propertyDetails.getKey()); + if (config != null) { + config.recordUsage(createPropertyDetails(propertyDetails.getKey(), propertyDetails.getValue())); } }