Thread-c объектом с подклассом NSobject - PullRequest
0 голосов
/ 22 июля 2011

Я использую класс потоков (.h / .m ниже), где подкласс UIViewcontroller работает без проблем.

@interface myFirstClass : UIViewController <MyOperationDelegate>{

Однако, когда я использую его, когда подкласс является NSobject для вызова класса достижимости, проверяющего подключение к Интернету, приложение вылетает при вызове executeSelectorOnMainThread? Я не понимаю, почему, когда я создаю приложение, не возникает ошибки, и когда он падает, все, что я получаю, это EXC_BAS_ACCESS. Разве это невозможно сделать при работе с NSObject? Любое предложение будет полезно для меня.

@interface AppController : NSObject <MyOperationDelegate>{

myThreading.h

@protocol MyOperationDelegate
    @required
    -(void) updatedStatus:(NSArray*)items;
    -(void) failedStatusWithError:(NSError*)error;
@end

@interface MyOperation : NSObject {    
    NSObject<MyOperationDelegate> * delegate;
    NSOperationQueue *queue;
}

@property (retain) NSObject<MyOperationDelegate> *delegate;

-(void)load: (NSString *)stringUrlPath:(NSString *)functionAction;

@end

myThreading.m

@interface MyOperation (NSObject)
    -(void)dispatchLoadingOperation:(NSDictionary *)aParameters;        
@end


@implementation MyOperation

@synthesize delegate;

-(id)init   
{
    if ([super init]!=nil) {
        queue = [NSOperationQueue new];
        [queue setMaxConcurrentOperationCount:1];
    }
    return self;
}

-(void)load: (NSString *)stringUrlPath: (NSString *)functionAction {

    [self dispatchLoadingOperation:[NSDictionary dictionaryWithObjectsAndKeys:
                                        stringUrlPath, @"urlString", functionAction, @"action", nil]];
}

-(void)dealloc {
        [queue cancelAllOperations];
        self.delegate = nil;
        [super dealloc];
}

-(void)dispatchLoadingOperation:(NSDictionary *)aParameters {

    if([aParameters objectForKey:@"action"] == @"getStatus"){
        @synchronized(self) {
            NSInvocationOperation *operation = [[NSInvocationOperation alloc] initWithTarget:self
                                                                                        selector:@selector(fetchCheckStatus:)
                                                                                          object:aParameters];
            [queue addOperation:operation];
            [operation release];
        }
    }
}


-(void) fetchCheckStatus:(NSDictionary *)aParameters
{   

    NSData* data = [[NSMutableData alloc] initWithContentsOfURL:[NSURL URLWithString:[aParameters objectForKey:@"urlString"]] ];

    NSError *error;
    NSString *responseString = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];

    if (responseString != nil) {

        NSMutableArray *rssItems;

        [self.delegate performSelectorOnMainThread:@selector(updatedStatus:) withObject:[NSArray arrayWithObjects:rssItems, nil] waitUntilDone:NO];


    } else {
            [queue cancelAllOperations];
            [self.delegate performSelectorOnMainThread:@selector(failedStatusWithError:) withObject:error waitUntilDone:NO];
    }

    [responseString autorelease];
    [data release];
}
@end 

1 Ответ

0 голосов
/ 22 июля 2011

Проблема в следующих строках:

NSMutableArray *rssItems;

[self.delegate performSelectorOnMainThread:@selector(updatedStatus:) withObject:[NSArray arrayWithObjects:rssItems, nil] waitUntilDone:NO];

Вы объявляете переменную rssItems, но не устанавливаете ее. Он будет содержать случайный мусор из стека, который будет интерпретироваться как указатель. Может быть, иногда вам везет, и значение на самом деле является указателем на живой объект, но более вероятно, что разыменование вызывает ваш сбой.

Вам нужно фактически инициализировать переменную, например ::100100

NSMutableArray *rssItems = nil;

но я думаю, вы действительно хотите:

NSMutableArray *rssItems = [NSMutableArray array];
...