2014-12-31 3 views
7

При использовании JSONModel для анализа моих моделей я нашел это исключение.NSInvalidArgumentException - [__ NSCFString unsignedLongLongValue]: непризнанный селектор, отправленный в экземпляр

NSInvalidArgumentException -[__NSCFString unsignedLongLongValue]: unrecognized selector sent to instance 0x1782210c0 

Проблема есть место внутри JSONModel.m, потому что это зависит от [NSObject setValue:forKey:].

Я нашел способ легко воспроизвести его.

@property NSUInteger uintegerProperty; 
[...] 
[self setValue:@"1" forKey:@"uintegerProperty"]; 

Это работает на 32 бит, потому что setValue заканчивается вызовом longLongVaue, определенный в NSString, но в случае 64 бит это призывающих unsignedLongLongValue который не определен в NSString.

В моем конкретном случае проблема заключается в том, что это enum, используемый в модели.

typedef NS_ENUM(NSUInteger, kNotificationTypeEnum) 
{ 
    kNotificationTypeResponse = 1, 
    kNotificationTypeAlert = 2 
}; 

Каков наилучший способ справиться с этой ситуацией?

Стек след

2014-12-31 17:48:43.789 mobile-iOS[17851:613] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[__NSCFConstantString unsignedLongLongValue]: unrecognized selector sent to instance 0x10f1feeb0' 
*** First throw call stack: 
(
    0 CoreFoundation      0x0000000111b99495 __exceptionPreprocess + 165 
    1 libobjc.A.dylib      0x00000001118f099e objc_exception_throw + 43 
    2 CoreFoundation      0x0000000111c2a65d -[NSObject(NSObject) doesNotRecognizeSelector:] + 205 
    3 CoreFoundation      0x0000000111b8ad8d ___forwarding___ + 973 
    4 CoreFoundation      0x0000000111b8a938 _CF_forwarding_prep_0 + 120 
    5 Foundation       0x000000010ff2449b _NSSetUnsignedLongLongValueForKeyWithMethod + 63 
    6 Foundation       0x000000010fed5530 -[NSObject(NSKeyValueCoding) setValue:forKey:] + 259 
    7 mobile-iOS       0x000000010ee1834c -[AppDelegate application:didFinishLaunchingWithOptions:] + 140 
    8 UIKit        0x000000011051b3d9 -[UIApplication _handleDelegateCallbacksWithOptions:isSuspended:restoreState:] + 264 
    9 UIKit        0x000000011051bbe1 -[UIApplication _callInitializationDelegatesForURL:payload:suspended:] + 1605 
    10 UIKit        0x000000011051fa0c -[UIApplication _runWithURL:payload:launchOrientation:statusBarStyle:statusBarHidden:] + 660 
    11 UIKit        0x0000000110530d4c -[UIApplication handleEvent:withNewEvent:] + 3189 
    12 UIKit        0x0000000110531216 -[UIApplication sendEvent:] + 79 
    13 mobile-iOS       0x000000010eedf48b -[MMApplication sendEvent:] + 331 
    14 UIKit        0x0000000110521086 _UIApplicationHandleEvent + 578 
    15 GraphicsServices     0x0000000112df671a _PurpleEventCallback + 762 
    16 GraphicsServices     0x0000000112df61e1 PurpleEventCallback + 35 
    17 CoreFoundation      0x0000000111b1b679 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ + 41 
    18 CoreFoundation      0x0000000111b1b44e __CFRunLoopDoSource1 + 478 
    19 CoreFoundation      0x0000000111b44903 __CFRunLoopRun + 1939 
    20 CoreFoundation      0x0000000111b43d83 CFRunLoopRunSpecific + 467 
    21 UIKit        0x000000011051f2e1 -[UIApplication _run] + 609 
    22 UIKit        0x0000000110520e33 UIApplicationMain + 1010 
    23 mobile-iOS       0x000000010ee2af23 main + 243 
    24 libdyld.dylib      0x000000011230b5c9 start + 1 
) 
libc++abi.dylib: terminating with uncaught exception of type NSException 
Signal: 6 (signal SIGABRT) 
+0

Вы можете передать значение как 'NSNumber' вместо' NSString'? I.e., '... setValue: @ 1 ...' вместо этого? –

+0

Да, это работает, но в моем случае я разбираю данные непосредственно из веб-канала, который отправляется как NSString. – 7ynk3r

+0

Исключительная трассировка стека? –

ответ

3

Самый простой способ, вероятно, просто использовать более короткий целочисленный тип для свойства, как uint32_t. Второй проще всего было бы добавить категорию на NSString, которая предоставляет отсутствующий метод.

+1

я в конечном итоге добавить категорию, просто реализует сообщение '- (без знака долго долго) unsignedLongLongValue \t { \t \t возвращение self.longLongValue; \t} '. Благодаря! – 7ynk3r

6

Финиш решение, чтобы решить эту проблему:

@implementation NSString (UnsignedLongLongValue) 

- (unsigned long long)unsignedLongLongValue { 

    return self.longLongValue; 
} 

@end 

Спасибо!

0

У нас была ошибка с iPhone 5, за исключением того, что вместо unsignedLongLongValue у нас была ошибка longValue. Таким образом, мы использовали подход к той же категории со следующим кодом:

@implementation NSString (LongValue) 

- (long)longValue { 
    return (long) self.longLongValue; 
} 

@end 
Смежные вопросы

 Смежные вопросы