NSDateInterval
表示特定開始日期和結(jié)束日期之間的時(shí)間跨度的對(duì)象。
- 繼承自NSObject;
- NSDateInterval對(duì)象由startDate和endDate組成,表示兩個(gè)日期之間的間隔;
- startDate和endDate可以相等,若相等,NSDateInterval的值為0;
- endDate不能再startDate之前;
- 計(jì)算兩日期的間隔時(shí)間,并判斷日期是否在其中;
- 比較日期間隔并判斷它們是否相交。
創(chuàng)建時(shí)間間隔
// 創(chuàng)建日期為當(dāng)前時(shí)間的日期對(duì)象
NSDate *date = [NSDate date];// 2019-05-25 05:50:00 +0000
// 創(chuàng)建從當(dāng)前日期和時(shí)間到給定秒數(shù)的日期對(duì)象。
NSDate *date1 = [NSDate dateWithTimeIntervalSinceNow:24*60*60];//2019-05-26 05:50:00 +0000
// 開始日期和結(jié)束日期都為當(dāng)前日期的時(shí)間間隔
NSDateInterval *interval = [[NSDateInterval alloc]init];//(Start Date) 2019-05-25 05:50:00 +0000 + (Duration) 0.000000 seconds = (End Date) 2019-05-25 05:50:00 +0000
// 根據(jù)日期和持續(xù)時(shí)間創(chuàng)建時(shí)間間隔
NSDateInterval *interval1 = [[NSDateInterval alloc]initWithStartDate:date duration:24*60*60];//(Start Date) 2019-05-25 05:50:00 +0000 + (Duration) 86400.000000 seconds = (End Date) 2019-05-26 05:50:00 +0000
// 根據(jù)起始時(shí)間和結(jié)束時(shí)間創(chuàng)建時(shí)間間隔
NSDateInterval *interval2 = [[NSDateInterval alloc]initWithStartDate:date endDate:date1];//(Start Date) 2019-05-25 05:50:00 +0000 + (Duration) 86400.000000 seconds = (End Date) 2019-05-26 05:50:00 +0000
訪問(wèn)時(shí)間
// 開始日期和結(jié)束日期都為當(dāng)前日期的時(shí)間間隔
NSDateInterval *interval = [[NSDateInterval alloc]init];//(Start Date) 2019-05-25 05:50:00 +0000 + (Duration) 0.000000 seconds = (End Date) 2019-05-25 05:50:00 +0000
// 獲取時(shí)間間隔的起始時(shí)間
NSDate *startDate = interval.startDate;// 2019-05-25 05:50:00 +0000
// 獲取時(shí)間間隔的結(jié)束時(shí)間
NSDate *endDate = interval.endDate;// 2019-05-25 05:50:00 +0000
// 獲取時(shí)間間隔的持續(xù)時(shí)間
NSTimeInterval timeInterval = interval.duration;//0
比較時(shí)間間隔
// 比較時(shí)間間隔
NSComparisonResult result = [interval compare:interval1];//NSOrderedDescending
// 判斷兩時(shí)間間隔是否相等
BOOL isEqual = [interval isEqualToDateInterval:interval1];//NO
判斷日期相交
// 判斷兩時(shí)間間隔是否相交
BOOL isIntersect = [interval intersectsDateInterval:interval1];//YES
// 獲取兩時(shí)間間隔的交集
NSDateInterval *interval3 = [interval intersectionWithDateInterval:interval1];//(Start Date) 2019-05-25 05:50:00 +0000 + (Duration) 0.000000 seconds = (End Date) 2019-05-25 05:50:00 +0000
判斷日期是否在日期間隔內(nèi)
// 判斷時(shí)間間隔是否包含指定日期
BOOL isContain = [interval containsDate:date];//NO