All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.fabric8.apmagent.metrics.ThreadContextMethodMetrics Maven / Gradle / Ivy

There is a newer version: 2.2.174
Show newest version
/**
 *  Copyright 2005-2016 Red Hat, Inc.
 *
 *  Red Hat licenses this file to you 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
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 *  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 io.fabric8.apmagent.metrics;

import com.codahale.metrics.Timer;

import java.util.concurrent.atomic.AtomicReference;

public class ThreadContextMethodMetrics extends MethodMetrics {
    private final Thread thread;
    private final AtomicReference stackRef;
    private Timer.Context timerContext;

    public ThreadContextMethodMetrics(Thread thread, AtomicReference stackRef, String name) {
        super(name);
        this.thread = thread;
        this.stackRef = stackRef;
    }

    public String getThreadName() {
        return thread.getName();
    }

    public long getThreadId() {
        return thread.getId();
    }

    public void onEnter() {
        timerContext = timer.time();
        stackRef.get().push(this);
    }

    public long onExit() {
        long result = -1;
        ThreadContextMethodMetrics last = stackRef.get().pop();
        if (last == this) {
            result = timerContext.stop();
        } else {
            //the exit could have jumped a few methods if its
            //caused by an exception
            while (last != null && last != this) {
                result = last.timerContext.stop();
                last = stackRef.get().pop();
            }
            if (last == this) {
                result = timerContext.stop();
            }
        }
        return result;
    }

    public String toString() {
        return "ThreadContextMethodMetrics:" + getName();
    }
}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy