gpt4 book ai didi

java - 重复事件库

转载 作者:搜寻专家 更新时间:2023-11-01 07:48:48 24 4
gpt4 key购买 nike

我正在尝试为我的应用程序实现议程功能,但直到现在我还没有找到任何可以帮助我实现此目的的库。我读过有关 Calendar Provider 和 Google Calendar API 的信息,但在他们的文档中没有找到任何有关仅为我的应用程序创建事件的信息。

目前我已经创建了一个数据库来存储具有以下结构的事件:

id - Integer used as primary key for the event;
user_id - Integer used to bound the user;
start_date - Date of the event;
end_date - Date with the end of the event's recurrence.
rec_sunday - Boolean if the event reoccurs on sunday.
rec_monday - Boolean if the event reoccurs on monday.
rec_tuesday - Boolean if the event reoccurs on tuesday.
rec_wednesday - Boolean if the event reoccurs on wednesday.
rec_thursday - Boolean if the event reoccurs on thursday.
rec_friday - Boolean if the event reoccurs on friday.
rec_saturday - Boolean if the event reoccurs on saturday.
recurrence - Boolean if the event has recurrence, so I won't need to check for all others booleans.

现在,我只需要一些逻辑来在 ArrayList 中创建事件以及重复发生的事件及其日期,这样之后我就可以使用日期作为基础的比较器对它们进行排序。

感谢您的帮助。

更新

感谢Basil Bourque我现在正在使用 ThreeTenABP 的惊人答案图书馆。这是一个很棒的库,而且比我想象的更容易使用。

最佳答案

other Answer by Ali可能是要走的路,使用 iCal4j。

但是要直接回答你的问题......

java.time

java.time框架内置于 Java 8 及更高版本中。这些类取代了旧的麻烦的日期时间类,例如 java.util.Date.Calendarjava.text.SimpleDateFormat

要了解更多信息,请参阅 Oracle Tutorial .并在 Stack Overflow 中搜索许多示例和解释。

许多 java.time 功能在 ThreeTen-Backport 中被反向移植到 Java 6 和 7并在 ThreeTenABP 中进一步适配 Android .

星期几

java.time.DayOfWeek枚举在这里会很方便。

EnumSetSet 的一个特殊实现,它在内部使用位图来表示枚举元素的集合,占用非常的内存,操作速度非常。这里的想法是使用 EnumSet 而不是您的每周 boolean 值方法。不需要关于重复的额外 boolean 值,因为您可以看到 EnumSet 是否有任何元素;没有元素意味着没有重复。

本地日期

LocalDate类表示没有时间和时区的纯日期值。

顺便说一句,在standard date-handling , 一周从星期一开始到星期日结束。虽然您可能不想以这种方式向用户展示一周,但我建议在内部坚持使用标准。这种周一到周日的方法也是 DayOfWeek 枚举中定义的顺序。

你的类(class)

Event 定义一个类。

public class Event {
Integer id ;
Integer user_id ;
LocalDate start , stop ;
Set< DayOfWeek > recurrence ;
}

如果您愿意,可以使用空集初始化recurrence EnumSet。

recurrence = EnumSet.noneOf( DayOfWeek.class );

然后添加项目。从数据库中检索数据时,您可以使用 if 语句执行此操作,如果行的 SQL BOOLEAN 列值为 TRUE,则调用 .add方法在这里。

recurrence.add( DayOfWeek.MONDAY );

检查集的大小以查看此事件是否重复出现。

Boolean isRecurring = ( recurrence.size() > 0 );

要对对象进行排序,请执行 Comparable通过简单地委托(delegate)给 start 成员的 LocalDate 实现。我不记得带有 Comparable 的泛型的确切语法,但这是粗略的想法。

public class Event implements Comparable {

@Override
public int compareTo( Event otherEvent ) {
return this.start.compareTo( otherEvent.start ) ;
}

填写一个List每次出现时,都执行类似此循环的操作。

A TemporalAdjuster操作日期时间对象以生成新的日期时间对象。 TemporalAdjusters (注意复数)类提供实现,包括我们需要的 next 和/或 nextOrSame . start 可能需要作为事件包含在内;我将把技巧留给读者作为练习。 ;-)

if( recurrences.size > 0 ) { // If any recurrences to schedule…
List<LocalDate> occurrences = new ArrayList<>();
LocalDate ld = this.start ;
while ( ld.isBefore( this.stop ) ) {
for( DayOfWeek dow , this.recurrence ) {
ld = ld.with( TemporalAdjusters.next( dow ) );
occurrences.add( ld );

请注意上面代码中的逻辑,我们测试每个日期停止日期之前,小于或等于。这种半开放方法在日期时间工作中很常见,其中时间跨度定义为开始为包含,结束为不包含

您可能想要全面检查开始和停止之间的时间跨度。如果一个错误导致了一个荒谬的长间隔,你可能会用大量的 List 出现来耗尽内存。 Period类有助于此检查。

if ( Period.between( start , stop ).getYears() > 10 )  {   // If over a decade, halt. 

警告:以上所有代码都未经测试且从未运行。就在我的头顶。希望足以帮助您入门。

对于调度,考虑 Quartz Job Scheduler .

关于java - 重复事件库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38414140/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com