/** * Copyright 2013 Netflix, Inc. * <p/> * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * <p/> * http://www.apache.org/licenses/LICENSE-2.0 * <p/> * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.netflix.servo.monitor; import java.util.concurrent.atomic.AtomicLong; /** * A {@link Gauge} that reports a long value. */ public class LongGauge extends NumberGauge { private final AtomicLong number; /** * Create a new instance with the specified configuration. * * @param config configuration for this gauge */ public LongGauge(MonitorConfig config) { super(config); number = new AtomicLong(0L); setBackingNumber(number); } /** * Set the current value. */ public void set(Long n) { AtomicLong number = getNumber(); number.set(n); } /** * Returns a reference to the {@link java.util.concurrent.atomic.AtomicLong}. */ public AtomicLong getNumber() { return number; } /** * {@inheritDoc} */ @Override public boolean equals(Object o) { if (this == o) { return true; } if (o == null || getClass() != o.getClass()) { return false; } LongGauge that = (LongGauge) o; return getConfig().equals(that.getConfig()) && getValue(0).equals(that.getValue(0)); } /** * {@inheritDoc} */ @Override public int hashCode() { int result = getConfig().hashCode(); result = 31 * result + getValue(0).hashCode(); return result; } /** * {@inheritDoc} */ @Override public Number getValue(int pollerIdx) { // we return the actual value at the time of the call and not a reference // to the atomic number so the value doesn't change and is also available to jmx viewers return number.get(); } }