最新の SDK を使用して iOS 5.0 以降のアプリを開発しています。
このコードで非常に奇妙なエラーが発生します。
- (NSMutableURLRequest*)setupRequestWithService:(NSString*)service andMethod:(NSString*)method
{
NSString* url = [NSString stringWithFormat:@"%@%@.svc/%@", serverUrl, service, method];
NSMutableURLRequest* request = [[NSMutableURLRequest alloc] initWithURL:[NSURL URLWithString:url]];
// Set authentication token.
NSLog(@"???????????? %@", authenticationToken);
if (authenticationToken == nil)
NSLog(@"NULL AUTHTOKEN");
if ([authenticationToken isEqual:[NSNull null]])
NSLog(@"NSNULL AUTHTOKEN");
if (request == nil)
NSLog(@"NULL REQUEST");
[request addValue:authenticationToken forHTTPHeaderField:REQUEST_HEADER_AUTH_TOKEN];
return request;
}
これは私のログです:
???????????? <null>
NSNULL AUTHTOKEN
-[NSNull length]: unrecognized selector sent to instance 0x3b5a5090
*** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[NSNull length]: unrecognized selector sent to instance 0x3b5a5090'
のようauthenticationToken
ですNULL
。しかし、それがログに表示されない理由でauthenticationToken
ある場合、私はそれを理解していません。NULL
NULL AUTHTOKEN
このメソッドを 2 回目に実行するとこのエラーが発生しますが、最初はエラーは発生しません。これは私のログです:
???????????? (null)
NULL AUTHTOKEN
ところで:
NSString* authenticationToken;
何かアドバイス?
Memory Leak
どこかにあるのかな…