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

com.graphaware.reco.generic.stats.DefaultTaskTimer Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2013-2016 GraphAware
 *
 * This file is part of the GraphAware Framework.
 *
 * GraphAware Framework is free software: you can redistribute it and/or modify it under the terms of
 * the GNU General Public License as published by the Free Software Foundation, either
 * version 3 of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 * See the GNU General Public License for more details. You should have received a copy of
 * the GNU General Public License along with this program.  If not, see
 * .
 */

package com.graphaware.reco.generic.stats;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;

import static com.graphaware.reco.generic.util.Assert.hasLength;


/**
 * Default production implementation of {@link com.graphaware.reco.generic.stats.TaskTimer}.
 */
public class DefaultTaskTimer implements TaskTimer {

    private static final Logger LOG = LoggerFactory.getLogger(DefaultTaskTimer.class);

    private final ConcurrentMap startTimes = new ConcurrentHashMap<>();

    /**
     * {@inheritDoc}
     */
    @Override
    public void startTiming(String task) {
        hasLength(task);

        if (startTimes.putIfAbsent(task, System.currentTimeMillis()) != null) {
            LOG.warn("Task " + task + " already timing! Not restarting timer...");
        }
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public long getTime(String task) {
        hasLength(task);

        Long start = startTimes.get(task);

        if (start == null) {
            LOG.warn("Could not timing stop non-existing task " + task);
            return -1;
        }

        return System.currentTimeMillis() - start;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy