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

com.github.frontear.efkolia.utilities.timing.Timer Maven / Gradle / Ivy

package com.github.frontear.efkolia.utilities.timing;

import com.github.frontear.internal.NotNull;
import java.util.concurrent.TimeUnit;
import lombok.NonNull;

/**
 * A utility which tracks certain durations to the accuracy of nanoseconds. It makes use of {@link
 * System#nanoTime()} to achieve high precision duration timing. Furthermore, it allows you to
 * seamlessly convert the time information into other types, by making use of {@link TimeUnit}.
 */
public final class Timer {
    private long nanos;

    /**
     * Creates a new instance of a timer. It will internally invoke {@link Timer#reset()}.
     */
    public Timer() {
        this.reset();
    }

    /**
     * Resets the internal nanos to the most recent value received from {@link System#nanoTime()}.
     */
    public void reset() {
        this.nanos = System.nanoTime();
    }

    /**
     * Checks if the elapsed nano seconds are equivalent to a specific point of time. This
     * internally uses {@link Timer#getElapsed(TimeUnit)}.
     *
     * @param unit The unit to compare with. Internally calls {@link TimeUnit#convert(long,
     *             TimeUnit)}.
     * @param time The elapsed value, this MUST match the specified unit.
     *
     * @return Whether enough time has elapsed.
     */
    public boolean hasElapsed(@NonNull final TimeUnit unit, final long time) {
        return getElapsed(unit) >= time;
    }

    /**
     * Converts the elapsed nanosecond time to a specified {@link TimeUnit}.
     *
     * @param unit The specified unit type.
     *
     * @return An elapsed value converted into the specified units.
     */
    public long getElapsed(@NonNull final TimeUnit unit) {
        return unit.convert(System.nanoTime() - nanos, TimeUnit.NANOSECONDS);
    }

    /**
     * Converts the elapsed nanosecond time into a time string. By default, this will return the
     * format "HH:mm:ss:SSS".
     *
     * @return A formatted time string.
     */
    @NotNull
    @Override
    public String toString() {
        return String.format("%02d:%02d:%02d:%03d", getElapsed(TimeUnit.HOURS) % 24,
            getElapsed(TimeUnit.MINUTES) % 60, getElapsed(TimeUnit.SECONDS) % 60,
            getElapsed(TimeUnit.MILLISECONDS) % 1000);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy