From: Robert Varga Date: Tue, 8 Nov 2022 11:26:22 +0000 (+0100) Subject: Use a VarHandle for closed flag X-Git-Tag: v7.0.0~45 X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=commitdiff_plain;h=6c80d1009ea11d5cc058d0b2123b933efa5b58cf Use a VarHandle for closed flag This eliminates type safety warnings and make it more explicit as to what we mean. Change-Id: I2335ff7c970ec7f5f55624a02a0c49b349deaa64 Signed-off-by: Robert Varga --- diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/AbstractDOMTransactionFactory.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/AbstractDOMTransactionFactory.java index afbef9dd71..4d488a1873 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/AbstractDOMTransactionFactory.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/AbstractDOMTransactionFactory.java @@ -10,10 +10,11 @@ package org.opendaylight.controller.cluster.databroker; import com.google.common.base.Preconditions; import com.google.common.util.concurrent.FluentFuture; +import java.lang.invoke.MethodHandles; +import java.lang.invoke.VarHandle; import java.util.Collection; import java.util.EnumMap; import java.util.Map; -import java.util.concurrent.atomic.AtomicIntegerFieldUpdater; import org.opendaylight.mdsal.common.api.CommitInfo; import org.opendaylight.mdsal.common.api.LogicalDatastoreType; import org.opendaylight.mdsal.dom.api.DOMDataTreeReadTransaction; @@ -26,13 +27,19 @@ import org.slf4j.LoggerFactory; public abstract class AbstractDOMTransactionFactory implements AutoCloseable { private static final Logger LOG = LoggerFactory.getLogger(AbstractDOMTransactionFactory.class); - @SuppressWarnings("rawtypes") - private static final AtomicIntegerFieldUpdater UPDATER = - AtomicIntegerFieldUpdater.newUpdater(AbstractDOMTransactionFactory.class, "closed"); + private static final VarHandle CLOSED; + + static { + try { + CLOSED = MethodHandles.lookup().findVarHandle(AbstractDOMTransactionFactory.class, "closed", boolean.class); + } catch (NoSuchFieldException | IllegalAccessException e) { + throw new ExceptionInInitializerError(e); + } + } private final Map storeTxFactories; - private volatile int closed = 0; + private volatile boolean closed; protected AbstractDOMTransactionFactory(final Map txFactories) { this.storeTxFactories = new EnumMap<>(txFactories); @@ -112,12 +119,12 @@ public abstract class AbstractDOMTransactionFactory