Jakim sarkastycznym błędem jest ten iOS?

83

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 dateAtBeginningOfDayForDatemetoda ź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 NSLocaledo formatowania danych wyjściowych. Z tego, co się wydaje, będę musiał zmienić swoją dateAtBeginningOfDayForDatepracę również na arenie międzynarodowej.

losowy
źródło
40
OK, to mnie rozśmieszyło. Ktoś w Apple ma okrutne poczucie humoru ...
nneonneo
3
Mówi, że istnieje ślad wstecz. Co jest w śladzie?
nneonneo,
2
Cóż, byłem ciekawy, która z tych dwóch linii uległa awarii. Jaka jest wartość formatString?
nneonneo,
2
Czy naprawdę zawiesza się na jednej z tych dwóch linii? W tym miejscu pomógłby ślad wstecz ...
nneonneo
2
Myślę, że to dość oczywiste z kodu, który pisał i błędu masz, że inputDatemusi być nil. Przyjrzyj się ramkom z wyższego stosu i zobacz, czy możesz dowiedzieć się, co może wysłać nildatę wejściową.
nneonneo,

Odpowiedzi:

16

Błąd nie występuje w opublikowanym kodzie. Oznacza to, że gdzieś masz coś, co powinno być, NSDatea zamiast tego jest nil.

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

Plik analogowy
źródło
Ma około mili, naprawdę niewiele. Chodzi o to, że jeśli uruchomię powyższy kod na urządzeniu, tylko [fmt setDateFormat:@"HH:mm dd MMM yyyy"];on działa dobrze. Więc zakładam, że dateFormatFromTemplate:jest to w jakiś sposób złe.
losowy
Ten komentarz jest powiązany tylko z humorem ... Kiedyś musiałem zmodyfikować źródło na sterownik dysku SunOS SCSI (sd.c). Nad pewnym kodem do testowania bitów był komentarz, który powiedział / * snarf yummos ze smacznych kawałków * /
JohnQ
6

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ę NSDateFormatterustawienia 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 NSDateFormattertak wyglądało po zlokalizowaniu.

MMM dd, yyyy, HH:mm

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 yyyypowodowało jego powrót nil.

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ę NSDatedla użytkowników odpowiednie ustawienia regionalne.

losowy
źródło
Musisz także zdawać sobie sprawę z „funkcji” ustawień regionalnych .
Hot Licks