Giter Site home page Giter Site logo

cronex's Introduction

CronEx

Ultra quick scheduler with milliseconds (or microseconds) resolution.

The average event search time is up to 200ns. The average time of events generation is up to 20ns. The source schedule can be of any complexity. Thread-Safe. Unmodifiable. Ready to work implementation (see the current release).

If you want make microseconds resolution see the algorithm description (Russian version).

Usage

import com.habr.cron.Cron;
import com.habr.cron.Schedule;
import com.habr.cron.ScheduleFormatException;
import com.habr.cron.ScheduleEventsGenerator;

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.TimeZone;
 
/*
 * Classic usage
 */
public static void main(String args[]) throws ScheduleFormatException
{
  Cron cron = new Schedule("*.*.20-32 12:00:00");
  
  SimpleDateFormat f = new SimpleDateFormat("dd.MM.yyyy HH:mm:ss.SSS");
  f.setTimeZone(TimeZone.getTimeZone("UTC"));
    
  // searches date of the next event at this moment
  Date date = f.parse("30.04.2021 12:00:00.000");
  Date next = cron.NextEvent(date);
} 

/*
 * Use generator of events
 */
public static void main(String args[]) throws Exception
{
  Schedule schedule = new Schedule("*.*.20-32 12:00:00");

  SimpleDateFormat f = new SimpleDateFormat("dd.MM.yyyy HH:mm:ss.SSS");
  f.setTimeZone(TimeZone.getTimeZone("UTC"));
  Date date = f.parse("30.04.2021 12:00:00.000");

  // gets a generator for events series, starting from specified date
  ScheduleEventsGenerator generator = schedule.getEventsGenerator(date, true);

  // generate series of next events
  for (int i = 0; i < 1000; i++)
  {
    System.out.println(generator.next());
  }
}

Format of schedule:

yyyy.MM.dd w HH:mm:ss.fff

yyyy.MM.dd HH:mm:ss.fff

HH:mm:ss.fff

yyyy.MM.dd w HH:mm:ss    

yyyy.MM.dd HH:mm:ss    

HH:mm:ss    

Where are:

yyyy - year (2000-2100)

MM - month (1-12)

dd - day of month (1-31 or 32). The 32th means a last day of month.

w - day of weed (0-6). 0 - sunday, 1 - monday, ... 6 - saturday

HH - hours (0-23)

mm - minutes (0-59)

ss - seconds (0-59)

fff - milliseconds (0-999). If not present, default is 0.

Each part of the date/time can be set as lists and ranges:

1,2,3-5,10-20/3 - means the list of values: 1,2, 3,4,5, 10,13,16,19

Step in range defines via slash. Asterisk means any possible value:

*/4 - means list of values: 0,4,8,12,16,20

You can specify 32 for a last day of month:

*.*.32 12:00:00 - means exactly at 12:00 on the last day of the month

*.*.20-32/3 12:00:00 - means exactly at 12:00 on the 20th, 23th, 26th, ... until the end of the month in increments of 3.

Schedule examples:

*.9.*/2 1-5 10:00:00.000 - means exactly at 10:00 on all days from Mon. to Fri. on odd numbers in September    

*:00:00 - means the beginning of any hour    

*.*.01 01:30:00 - means exactly at 01:30 on the first days of each month    

Handle exceptions

The scheduler can throws ScheduleFormatException if the schedule is set incorrectly. For example, it's an empty schedule, or time not present, or some number cann't be parsed.

The scheduler can throws IllegalStateException when the next value if out of schedule. For example, the schedule is set only for 2021, but the current date is 2022.

/*
 * handle exception due parsing
 */
public static void main(String args[]) throws ScheduleFormatException
{
  try
  {
     Cron cron = new Schedule("2012.12.31"); // invalid of schedule format
  }
  catch(ScheduleFormatException e)
  {
     System.out.prinln(e.getMessage()); // "Time MUST follow AFTER date. Trouble in this schedule: 2012.12.31"
  }
} 

/*
 * handle exception due searching
 */
public static void main(String args[]) throws ScheduleFormatException
{
  Cron cron = new Schedule("2012.12.31 *:*:*"); // the date of the "End of the World"
  
  try
  {
     Date current = new Date();
     Date next = cron.NextEvent(current);
  }
  catch(IllegalStateException e)
  {
     System.out.prinln(e.getMessage());
  }
} 

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.