Mam kod, którego używam do sortowania dat w kalendarzu, który wygląda następująco:
#if !(TARGET_IPHONE_SIMULATOR)
NSString *formatString = [NSDateFormatter dateFormatFromTemplate:@"HH:mm dd MMM yyyy" options:0
locale:[NSLocale currentLocale]];
[fmt setDateFormat:formatString];
#else
[fmt setDateFormat:@"HH:mm dd MMM yyyy"];
#endif
Jeśli uruchomię to w symulatorze, wszystko jest w porządku. Jeśli uruchomię go na urządzeniu, otrzymam ten sarkastyczny komunikat debugowania.
2012-09-19 22: 40: 13.972 APPNAME [4923: 907] * - [__ NSCFCalendar składniki: fromDate:]: data nie może być zerowa
Naprawdę, jak myślisz, co ma oznaczać ta operacja z zerową datą?
Na razie uniknięto wyjątku.
Kilka z tych błędów zostanie zgłoszonych z tą skargą, a kolejne naruszenia po prostu po cichu zrobią to, co przypadkowe spowoduje zera. Oto ślad śledzenia, w którym to się stało tym razem (może brakować niektórych ramek z powodu optymalizacji kompilatora):
Musisz się z tego śmiać, ale nie jestem pewien, co jest nie tak z moim dateFormatFromTemplate:
kodem. Każda pomoc będzie mile widziana.
Uruchamiam Xcode V 4,5 btw
AKTUALIZACJA:
Ślad:
0 CoreFoundation 0x39ff0e55 + 84
1 APPNAME 0x00040be1 - [MeetingsViewController dateAtBeginningOfDayForDate:] + 140
Więc myślę, że moja dateAtBeginningOfDayForDate
metoda źle się układa. Co wygląda tak:
/*
Break down a given NSDate to its bare components for sorting
*/
- (NSDate *)dateAtBeginningOfDayForDate:(NSDate *)inputDate
{
// Use the user's current calendar and time zone
NSCalendar *calendar = [NSCalendar currentCalendar];
NSTimeZone *timeZone = [NSTimeZone systemTimeZone];
[calendar setTimeZone:timeZone];
// Selectively convert the date components (year, month, day) of the input date
NSDateComponents *dateComps = [calendar components:NSYearCalendarUnit | NSMonthCalendarUnit | NSDayCalendarUnit fromDate:inputDate];
// Set the time components manually
[dateComps setHour:0];
[dateComps setMinute:0];
[dateComps setSecond:0];
// Convert back
NSDate *beginningOfDay = [calendar dateFromComponents:dateComps];
return beginningOfDay;
}
Używam tej metody, aby rozbić dany NSDate na jego podstawowe komponenty, aby móc je wszystkie bardziej efektywnie sortować. Jednak moja aplikacja musi być międzynarodowa, co jest powodem używania NSLocale
do formatowania danych wyjściowych. Z tego, co się wydaje, będę musiał zmienić swoją dateAtBeginningOfDayForDate
pracę również na arenie międzynarodowej.
źródło
formatString
?inputDate
musi byćnil
. Przyjrzyj się ramkom z wyższego stosu i zobacz, czy możesz dowiedzieć się, co może wysłaćnil
datę wejściową.Odpowiedzi:
Błąd nie występuje w opublikowanym kodzie. Oznacza to, że gdzieś masz coś, co powinno być,
NSDate
a zamiast tego jestnil
.Jeśli chodzi o humor w komunikacie o błędzie, nigdy nie widziałem tego komunikatu, ale +1 do Apple. Jakiś inżynier w dziale Cocoa jest tak zabawny, jak starzy, dobrzy inżynierowie Apple mieli wiele lat temu.
Sprawdź rodzaj diagnostyki kompilator MPW C firmy Apple użyty do wyplucia http://www.netfunny.com/rhf/jokes/91q3/cerrors.html
źródło
[fmt setDateFormat:@"HH:mm dd MMM yyyy"];
on działa dobrze. Więc zakładam, żedateFormatFromTemplate:
jest to w jakiś sposób złe.Wielkie dzięki dla Nneonneo za pomoc w rozwiązaniu tego problemu .
Mój problem polega na tym, że moja aplikacja musi działać na całym świecie, więc potrzebowałem wyświetlania dat w odniesieniu do lokalizacji użytkownika. Pomyślałem, że po prostu utworzę
NSDateFormatter
ustawienia regionalne dla użytkowników, a następnie przekażę datę w postaci ciągu:NSString *formatString = [NSDateFormatter dateFormatFromTemplate:@"HH:mm dd MMM yyyy" options:0 locale:[NSLocale currentLocale]]; date = [fmt dateFromString:[NSString stringWithFormat:@"%@ %@", obj.meetingTime, obj.meetingDate]];
Problem polega jednak na tym, że lokalizowałem format daty, zanim podałem datę w ciągu. W moim przypadku
NSDateFormatter
tak wyglądało po zlokalizowaniu.Który format po lokalizacji może wyglądać na wiele różnych sposobów po lokalizacji.
Zatem przekazanie ciągu znaków w formacie
HH:mm dd MMM yyyy
powodowało jego powrótnil
.Co jest teraz oczywiste -.-
Dlatego zamiast lokalizować podczas tworzenia daty, tworzę daty w standardowym formacie
HH:mm dd MMM yyyy
. Następnie podczas wyświetlania formatujęNSDate
dla użytkowników odpowiednie ustawienia regionalne.źródło