Я сделал несколько примеров кода, и результат может вас заинтересовать.
Я создал класс, который создает запрос так же, как ваш:
@implementation Aftest
@synthesize name = _name;
- (void) doSomeStuff
{
NSLog(@"Got here %@", self.name);
}
- (void)startDownload
{
self.name = [NSString stringWithFormat:@"name"];
NSURL *requestURL = [NSURL URLWithString:@"http://api.twitter.com/1/statuses/user_timeline.json?include_entities=true&include_rts=true&screen_name=twitterapi&count=2"];
NSURLRequest *request = [NSURLRequest requestWithURL:requestURL];
AFJSONRequestOperation *operation = [AFJSONRequestOperation operationWithRequest:request success:^(id JSON)
{
[self doSomeStuff];
} failure:^(NSHTTPURLResponse *response, NSError *error)
{
NSLog(@"%@", [error localizedDescription]);
}];
NSOperationQueue *queue = [[[NSOperationQueue alloc] init] autorelease];
[queue addOperation:operation];
}
@end
И назвал это с:
Aftest *af = [[Aftest alloc] init];
NSLog(@"1 - retain count %d", [af retainCount] );
[af startDownload];
NSLog(@"2 - retain count %d", [af retainCount] );
[af release];
NSLog(@"3 - retain count %d", [af retainCount] );
Результат, который я получил, был:
2011-10-09 09:28:41.415 aftes[6154:f203] 1 - retain count 1
2011-10-09 09:28:41.418 aftes[6154:f203] 2 - retain count 2
2011-10-09 09:28:41.419 aftes[6154:f203] 3 - retain count 1
2011-10-09 09:28:43.361 aftes[6154:f203] Got here name
Ваш объект должен быть сохранен при передаче внутри блока. Следует избегать этих сбоев.
В любом случае, как ответил Майкл, должна быть возможность вызвать cancel
, пока у вас есть доступ к операционному объекту.