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

co.paralleluniverse.strands.Timeout Maven / Gradle / Ivy

Go to download

The core library for Fibers on Java, compatible with Java 11-16. Forked from puniverse/quasar

There is a newer version: 10.0.6
Show newest version
/*
 * Quasar: lightweight threads and actors for the JVM.
 * Copyright (c) 2013-2014, Parallel Universe Software Co. All rights reserved.
 * 
 * This program and the accompanying materials are dual-licensed under
 * either the terms of the Eclipse Public License v1.0 as published by
 * the Eclipse Foundation
 *  
 *   or (per the licensee's choosing)
 *  
 * under the terms of the GNU Lesser General Public License version 3.0
 * as published by the Free Software Foundation.
 */
package co.paralleluniverse.strands;

import java.util.concurrent.TimeUnit;

/**
 * Represents a timeout that can span several operations.
 * This object expires within a given time from the instant this object has been created.
 * It maintains the time left until it expires, so it can be initialized once and then passed to several consecutive
 * operation, making sure that the sequence of operations completes within the timeout's duration.
 * 

* To use this timeout in methods that take a {@code long timeout} and a {@code TimeUnit unit} argument, pass:

*
{@code
 *     timeout.nanosLeft(), TimeUnit.NANOSECONDS
 * }
* * @author pron */ public class Timeout { private final long deadline; /** * Starts a new {@code Timeout} that begins now and expires within the given timeout * from the instant this constructor has been called. * * @param timeout the duration of the timeout * @param unit the timeout's time unit */ public Timeout(long timeout, TimeUnit unit) { this.deadline = System.nanoTime() + unit.toNanos(timeout); } /** * Returns how many nanoseconds are left before the timeout expires, * or a negative number indicating how many nanoseconds have elapsed since * the timeout expired. */ public long nanosLeft() { return deadline - System.nanoTime(); } /** * Returns how long is left before the timeout expires in the given time unit. * * @param unit the time unit of the return value * @return how long is left before the timeout expires in the given time unit. */ public long timeLeft(TimeUnit unit) { return unit.convert(nanosLeft(), TimeUnit.NANOSECONDS); } /** * Tests whether the timeout has expired. */ public boolean isExpired() { return nanosLeft() <= 0; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy