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

org.dromara.hutool.cron.pattern.CronPatternUtil Maven / Gradle / Ivy

There is a newer version: 6.0.0.M3
Show newest version
/*
 * Copyright (c) 2013-2024 Hutool Team and hutool.cn
 *
 * Licensed 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 org.dromara.hutool.cron.pattern;

import org.dromara.hutool.core.date.CalendarUtil;
import org.dromara.hutool.core.date.DateUtil;
import org.dromara.hutool.core.lang.Assert;

import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.List;

/**
 * 定时任务表达式工具类
 *
 * @author looly
 *
 */
public class CronPatternUtil {

	/**
	 * 列举指定日期之后(到开始日期对应年年底)内第一个匹配表达式的日期
	 *
	 * @param pattern 表达式
	 * @param start 起始时间
	 * @return 日期
	 * @since 4.5.8
	 */
	public static Date nextDateAfter(final CronPattern pattern, final Date start) {
		return DateUtil.date(pattern.nextMatchAfter(CalendarUtil.calendar(start)));
	}

	/**
	 * 列举指定日期之后(到开始日期对应年年底)内所有匹配表达式的日期
	 *
	 * @param patternStr 表达式字符串
	 * @param start 起始时间
	 * @param count 列举数量
	 * @return 日期列表
	 */
	public static List matchedDates(final String patternStr, final Date start, final int count) {
		return matchedDates(patternStr, start, DateUtil.endOfYear(start, false), count);
	}

	/**
	 * 列举指定日期范围内所有匹配表达式的日期
	 *
	 * @param patternStr 表达式字符串
	 * @param start 起始时间
	 * @param end 结束时间
	 * @param count 列举数量
	 * @return 日期列表
	 */
	public static List matchedDates(final String patternStr, final Date start, final Date end, final int count) {
		return matchedDates(patternStr, start.getTime(), end.getTime(), count);
	}

	/**
	 * 列举指定日期范围内所有匹配表达式的日期
	 *
	 * @param patternStr 表达式字符串
	 * @param start 起始时间
	 * @param end 结束时间
	 * @param count 列举数量
	 * @return 日期列表
	 */
	public static List matchedDates(final String patternStr, final long start, final long end, final int count) {
		return matchedDates(new CronPattern(patternStr), start, end, count);
	}

	/**
	 * 列举指定日期范围内所有匹配表达式的日期
	 *
	 * @param pattern 表达式
	 * @param start 起始时间
	 * @param end 结束时间
	 * @param count 列举数量
	 * @return 日期列表
	 */
	public static List matchedDates(final CronPattern pattern, final long start, final long end, final int count) {
		Assert.isTrue(start < end, "Start date is later than end !");

		final List result = new ArrayList<>(count);

		Calendar calendar = pattern.nextMatchAfter(CalendarUtil.calendar(start));
		while(calendar.getTimeInMillis() < end){
			result.add(DateUtil.date(calendar));
			if(result.size() >= count){
				break;
			}
			calendar = pattern.nextMatchAfter(calendar);
		}

		return result;
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy