Android 比较两个时间段是否有交集或重复

本文介绍了一种用于判断两个时间段是否重叠的方法,并提供了一个具体的实现案例。此方法适用于需要管理多个定时任务的应用场景,例如电池管理软件中的定时任务功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先看一个图:


在金山《电池管家》有一个类似上图这样的功能——开启多个定时任务

当开启一个定时任务的时候,如果这个定时任务的时间段与已经开启了的定时任务时间段有交集的话,它就会提示:重叠的任务不能同时启动!

下面是我写的判断两个时间段是否有重叠的一个方法。可能不完美或不高效,但能解决这个问题就行了。是吧!呵呵~~

/**
 * 比较两个时间段是否有交集工具类
 * @author qiulong
 * 
 */
public class TimeCheckUtil {

	/**
	 * 比较两个时间段数组是否有重合
	 * @author qiulong
	 * @param timeArray1
	 * @param timeArray2
	 * @return 有重合 true;
	 */
	public static boolean compare(ArrayList<Integer> timeArray1,
			ArrayList<Integer> timeArray2) {
		for (int i : timeArray1) {
			if (timeArray2.contains(i))
				return true;
		}
		return false;
	}

	/**
	 * 将时间段转换成数组
	 * @author qiulong
	 * @param ent
	 * @return
	 */
	public static ArrayList<Integer> checkList(TimingEntity ent) {
		// 先将时间转换成分来计算
		int timeStart = (ent.getStartHour() * 60) + ent.getStartMinute();
		int timeEnd = (ent.getEndHour() * 60) + ent.getEndMinute();
		// 将时间段封装成一个数组
		ArrayList<Integer> timeArray = new ArrayList<Integer>();
		if (timeEnd > timeStart) {// 开始时间小于结束时间
			for (int i = timeStart; i <= timeEnd; i++) {
				timeArray.add(i);// 添加开始时间至结束时间为止的时间
			}
		} else {// 开始时间大于结束时间
			for (int i = timeStart; i < 24 * 60; i++) {
				timeArray.add(i);// 添加开始时间至当天0点以前的剩余时间
			}
			for (int i = 0; i <= timeEnd; i++) {
				timeArray.add(i);// 添加0点以后到结束时间为止的时间
			}
		}
		return timeArray;
	}

}


以上仅供参考和学习,如有不好的地方欢迎指正和讨论。谢谢!

在Java中,判断两个时间区间(例如开始时间和结束时间构成的时间段是否交集,通常需要将它们转换成集合者数据结构来进行操作。这里可以考虑使用`java.time`包中的`LocalDateTime`类,以及集合类如`Interval`自定义类来表示时间段。 首先,定义一个时间段类,包含开始时间和结束时间: ```java import java.time.LocalDateTime; import java.time.Duration; public class TimeRange { private LocalDateTime start; private LocalDateTime end; // 构造函数、getter和setter... } ``` 然后你可以创建两个`TimeRange`对象,并定义一个方法来检查它们是否交集: ```java public boolean hasIntersection(TimeRange range1, TimeRange range2) { // 检查两个范围是否同时结束者开始 if (range1.getEnd().equals(range2.getStart())) { return true; // 如果两个端点相等,则有交集 } // 比较结束时间与另一个开始时间的大小 Duration overlap = range1.getEnd().compareTo(range2.getStart()); // 如果结束时间大于等于另一个开始时间并且小于另一个结束时间,说明有交集 return overlap >= 0 && overlap < Duration.between(range1.getStart(), range2.getEnd()); } // 使用示例: TimeRange range1 = new TimeRange(LocalDateTime.of(2023, 1, 1, 9, 0), LocalDateTime.of(2023, 1, 1, 12, 0)); TimeRange range2 = new TimeRange(LocalDateTime.of(2023, 1, 1, 11, 0), LocalDateTime.of(2023, 1, 1, 14, 0)); if (hasIntersection(range1, range2)) { System.out.println("两个时间段交集"); } else { System.out.println("两个时间段交集"); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值