これが私のコードです:
NSDate *currDate = [NSDate date];
NSDateFormatter *dateFormatter = [[NSDateFormatter alloc]init];
[dateFormatter setDateFormat:@"HH:mm:ss"];
NSString *currentTime = [dateFormatter stringFromDate:currDate];
NSDate *now = [NSDate date];
int interval = 1*60; // one minute (minutes*60)
long int nowSeconds = (long int) [now timeIntervalSince1970];
int secondsLeft = interval - (nowSeconds % interval);
NSDate *nextIntervalDate = [NSDate dateWithTimeIntervalSince1970:nowSeconds+secondsLeft];
NSString *nextTrigger = [dateFormatter stringFromDate:nextIntervalDate];
timeRemaining.text = [NSString stringWithFormat:@"%02d:%02d", secondsLeft/60, secondsLeft%60];
NSLog([NSString stringWithFormat:@"%@:%@", currentTime, nextTrigger]);
if ([currentTime isEqualToString:nextTrigger]) {
}
問題は、'if([currentTime isEqualToString:nextTrigger])'が決して等しくないことです。nextTriggerは、等しくなる前に次のタイムセグメントに変更されるためです。NSLogは次のとおりです。
2013-01-17 15:54:59.987 app[35987:c07] 15:54:59:15:55:00
2013-01-17 15:54:59.997 app[35987:c07] 15:54:59:15:55:00
2013-01-17 15:55:00.007 app[35987:c07] 15:55:00:15:56:00 <----RIGHT HERE
2013-01-17 15:55:00.016 app[35987:c07] 15:55:00:15:56:00
私のコードのnextTriggerは、基本的に現在の時刻を最も近い分で切り上げたものです。また、このコードセグメント全体は、0.1秒ごとに繰り返されるNSTimerにあります。
どうすればこれを修正できますか?