ASIHttpRequest проблемы. «нераспознанный селектор отправлен на экземпляр» - PullRequest
0 голосов
/ 11 апреля 2010

У меня проблемы с использованием ASIHttpRequst. Это ошибка, которую я получаю:

2010-04-11 20:47:08.176 citybikesPlus[5885:207] *** -[CALayer rackDone:]: unrecognized selector sent to instance 0x464a890
2010-04-11 20:47:08.176 citybikesPlus[5885:207] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '*** -[CALayer rackDone:]: unrecognized selector sent to instance 0x464a890'
2010-04-11 20:47:08.176 citybikesPlus[5885:207] Stack: (
    33936475,
    2546353417,
    34318395,
    33887862,
    33740482,
    126399,
    445238,
    33720545,
    33717320,
    40085013,
    40085210,
    3108783,
    11168,
    11022
)

И это мой код (часть его):

// Implement viewDidLoad to do additional setup after loading the view, typically from a nib.
- (void)viewDidLoad
{

 [image setImage:[UIImage imageNamed:@"bullet_rack.png"]];

 BikeAnnotation *bike = [[annotationView annotation] retain];

 bike._sub = @"";

    [super viewDidLoad];

 NSString *newUrl = [[NSString alloc] initWithFormat:rackUrl, bike._id];
 NSString *fetchUrl = [newUrl stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];

 [networkQueue cancelAllOperations];
 [networkQueue setRequestDidFinishSelector:@selector(rackDone:)];
 [networkQueue setRequestDidFailSelector:@selector(processFailed:)];
 [networkQueue setDelegate:self];

 ASIFormDataRequest *request = [[[ASIFormDataRequest alloc] initWithURL:[NSURL URLWithString:fetchUrl]] retain];
 [request setDefaultResponseEncoding:NSUTF8StringEncoding];
 [networkQueue addOperation:request];

 [networkQueue go];
}

- (void)rackDone:(ASIHTTPRequest *)request
{
 NSString *resultSearch = [request responseString];

 NSData *data = [resultSearch dataUsingEncoding:NSUTF8StringEncoding];

 NSString *errorDesc = nil;
 NSPropertyListFormat format;
 NSDictionary * dict = (NSDictionary*)[NSPropertyListSerialization
            propertyListFromData:data
            mutabilityOption:NSPropertyListMutableContainersAndLeaves
            format:&format
            errorDescription:&errorDesc];

 rackXmlResult* fileResult = [[[rackXmlResult alloc] initWithDictionary:dict] autorelease];
 rackXmlSet *rackSet = [fileResult getRackResult];

 NSString *subString = [[NSString alloc] initWithFormat:@"Cyklar tillgängligt: %@ -- Lediga platser: %@", rackSet._ready_bikes, rackSet._empty_locks];

 [activity setHidden:YES];
 [image setHidden:NO];

 BikeAnnotation *bike = [annotationView annotation];

 bike._sub = subString;
}

- (void) processFailed:(ASIHTTPRequest *)request
{
 UIAlertView *errorView;

 NSError *error = [request error];
 NSString *errorString = [error localizedDescription];

 errorView = [[UIAlertView alloc]
     initWithTitle: NSLocalizedString(@"Network error", @"Network error")
     message: errorString
     delegate: self
     cancelButtonTitle: NSLocalizedString(@"Close", @"Network error") otherButtonTitles: nil];

 [errorView show];
 [errorView autorelease];
}

Процесс загружается как LeftCalloutView в пузыре выноски, когда аннотации загружаются в мое представление карты, поэтому довольно много (80 раз или около того) Он предназначен для извлечения XML Plist с сервера, его анализа и использования данных ... но он умирает в rackDone:

У кого-нибудь есть идеи?

С уважением, Пол Пилен

Ответы [ 2 ]

1 голос
/ 12 апреля 2010

Что ж, похоже, проблема в том, что ваш объект networkQueue (что это за подкласс NSOperationsQueue?) Отправляет сообщение rackDone: представлению viewController вместо самого viewController. CALayers - это атрибуты представлений, а не viewControllers, поэтому ошибка должна исходить от представления.

Проверьте код для networkQueue.

Вы также, похоже, не используете нотацию self для networkQueue, и если это свойство класса, оно может умереть без предупреждения, поскольку оно не сохранено должным образом.

0 голосов
/ 12 апреля 2010

Я нашел решение, используя [self retain]. Кажется, что из-за того, что я загружаю объект так часто, он не выделяет его достаточно долго для получения rackDone: action.

Теперь работает. Теперь мне просто нужно выяснить, как я могу загрузить это по запросу, а не при загрузке приложения.

...