Синглтон для извлечения CoreData, сбой при [fetchedResultsController_ executeFetch: & error] - PullRequest
0 голосов
/ 11 марта 2011

Я создаю приложение для отправки OSC-сообщений через WLAN.
Вот почему у меня есть «Сетевой» объект с единственным объектом в нем. Из-за этого я хочу, чтобы Синглтон извлек этот объект.
В AppDelegate я создал Classmethod, чтобы получить ManagedObjectContext

static NSManagedObjectContext* manObCon;

@implementation...

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {  
   manObCon = self.managedObjectContext;
...
}

+ (NSManagedObjectContext*) getManObCon{
   return manObCon;
}

managedObjectContext приходит с адресом в моем синглтоне, поэтому я думаю, что он должен работать.
Singleton.h (здесь ничего особенного)

#import <Foundation/Foundation.h>
#import <CoreData/CoreData.h>
#import "OSC_iPadAppDelegate.h";
#import "Network.h";

@interface NetworkSingleton : NSObject <NSFetchedResultsControllerDelegate> {
}
+ (Network*) getNetwork;
+ (void) insertNewObject;
+ (NSFetchedResultsController *)fetchedResultsController;
@end

Приложение Singleton.m ломается при [fetchedResultsController_ performFetch:&error] с

warning: Unable to read symbols for /Developer/Platforms/iPhoneOS.platform/DeviceSupport/4.2.1 (8C148)/Symbols/usr/lib/info/dns.so (file not found).
Program received signal:  “EXC_BAD_ACCESS”.
warning: Unable to read symbols for /Developer/Platforms/iPhoneOS.platform/DeviceSupport/4.2.1 (8C148)/Symbols/Developer/usr/lib/libXcodeDebuggerSupport.dylib (file not found).
kill
quit

Вот код Singleton.m

#import "NetworkSingleton.h"
static Network* _network;
static NSFetchedResultsController *fetchedResultsController_;
static NSManagedObjectContext *managedObjectContext_;

@implementation NetworkSingleton

+ (Network*) getNetwork{
    managedObjectContext_ = [OSC_iPadAppDelegate getManObCon]; //get the managedObjectContex from AppDelegate
//fetchedResultsController init
    fetchedResultsController_ = [NetworkSingleton fetchedResultsController]; //get fetchedResultsController 
//check if _network is set
    if (_network == nil) {
        id <NSFetchedResultsSectionInfo> sectionInfo = [[fetchedResultsController_ sections] objectAtIndex:0];
//if not set, check if there is already an network object in coredata
        if ([sectionInfo numberOfObjects] == 0) {
            //Create new Networkobject, if no one is existing
            [NetworkSingleton insertNewObject];
            fetchedResultsController_ = nil;
        }
//set _network
        _network = [fetchedResultsController_ objectAtIndexPath:[NSIndexPath indexPathForRow:0 inSection:0]];
    }
    return _network;
}

+ (NSFetchedResultsController *)fetchedResultsController {

    if (fetchedResultsController_ != nil) {
        return fetchedResultsController_;
    }

    NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
    NSEntityDescription *entity = [NSEntityDescription entityForName:@"Network" inManagedObjectContext: managedObjectContext_];
    [fetchRequest setEntity:entity];

    [fetchRequest setFetchBatchSize:1];

    NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"sourcePort" ascending:YES selector:nil];
    NSArray *sortDescriptors = [[NSArray alloc] initWithObjects:sortDescriptor, nil];

    [fetchRequest setSortDescriptors:sortDescriptors];

    NSFetchedResultsController *aFetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:managedObjectContext_ sectionNameKeyPath:nil cacheName:nil];
    aFetchedResultsController.delegate = self;
    fetchedResultsController_ = aFetchedResultsController;

    [aFetchedResultsController release];
    [fetchRequest release];
    [sortDescriptor release];
    [sortDescriptors release];

    NSError *error = nil;
    /*
     APP CRASHES HER
     */
    if (![fetchedResultsController_ performFetch:&error]) { 
        NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
        abort();
    }

    return fetchedResultsController_;
}    
@end

Так что я не знаю, почему fetchedResultsController_ не делает то, что он делает лучше всего - fetch
это не ноль, но я не могу понять сообщение об ошибке и не нашел ничего ни в Google, ни где-либо еще.
Проблема может заключаться в том, что мне нужно самостоятельно инициировать fetchedResultsController, потому что он не запускается автоматически, как в сгенерированных контроллерах представления.

Спасибо за вашу помощь

1 Ответ

3 голосов
/ 11 марта 2011
NSFetchedResultsController *aFetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:managedObjectContext_ sectionNameKeyPath:nil cacheName:nil];

fetchedResultsController_ = aFetchedResultsController;

[aFetchedResultsController release];

Когда вы используете fetchedResultsController_ после этого блока кода, он уже освобожден. Потому что вы выделили его (retainCount + 1), а затем отпустили (retainCount-1). Вы не сохранили, когда назначили aFetchedResultsController для fetchedResultsController _.

либо сохраните это так fetchedResultsController_ = [aFetchedResultsController retain];
или уберите строку [aFetchedResultsController release];


РЕДАКТИРОВАТЬ: Я только что увидел, что может быть больше в вашем коде.

Вы должны заменить все fetchedResultsController_ за пределами геттера fetchedResultsController на self.fetchedResultsController. Обычно _ позади или перед переменной должно указывать вам, что вы должны использовать установщик и получатель, если вы не уверены, что делаете.

И fetchedResultsController_ = [NetworkSingleton fetchedResultsController]; вызывает fetchedResultsController_ = aFetchedResultsController;.
Что может сработать, но я бы не стал это делать.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...