Problemas asihttprequest. “Seletor não reconhecido enviado à instância”
-
26-09-2019 - |
Pergunta
Estou enfrentando problemas usando asihttprequst. Este é o erro que recebo:
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
)
E este é o meu código (parte dele):
// 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];
}
O processo é carregado como LeftCalloutView na bolha de envio quando as anotações são carregadas no meu MapView, então bastante (80 vezes mais). É com o objetivo de recuperar um Plist XML de um servidor, analisá -lo e usar os dados ... mas ele morre no Rackdone:
alguém tem alguma ideia?
Atenciosamente, Paul Peelen
Solução 2
Eu encontrei a solução usando [self retain]
. Parece que, como eu carrego o objeto com tanta frequência, ele não o aloca o tempo suficiente para receber o rackdone: ação.
Agora está funcionando. Agora eu só preciso descobrir como posso carregar isso mediante solicitação, não quando o aplicativo é carregado.
Outras dicas
Bem, o problema parece ser o seu networkQueue
objeto (o que quer que seja a subclasse nsoperationsqueue?) está enviando o rackDone:
Mensagem para a visão do ViewController em vez do próprio ViewController. As caligas são atributos de visualizações e não visualizadores de visualização, portanto o erro deve ser proveniente de uma visão.
Verifique o código para networkQueue
.
Você também não parece estar usando o self
notação para networkQueue
e se é uma propriedade da classe, pode morrer sem aviso, porque não é retida adequadamente.