iOS: Zombie Messaging при доступе к NSUserDefaults
При профилировании приложения для зомби я получаю сообщение об ошибке ниже:
стек:
Код:
Когда приложение запускается, мы получаем доступ к нескольким NSUserDefaults
свойства с использованием аналогичного кода, как показано ниже. Иногда приложение вылетает на разных методах, которые пытаются получить доступ к настройкам по умолчанию.
+(NSString*)getSettingsFileName{
prefs = [NSUserDefaults standardUserDefaults];
return [prefs objectForKey:@"SettingsFileName"]; // EXC_BAD_ACCES (code=1, address=0x8178b6ed)
}
Я пытался синхронизировать NSUserDefaults перед тем, как получить к нему доступ, но у меня такое же поведение.
Любые советы о том, как решить эту проблему, будет принята с благодарностью!
РЕДАКТИРОВАТЬ
+(void)readSettingsDataAndUpdateIncludeDomain:(BOOL)updateDomain MBMHost:(BOOL)updateMBMHost
{
//Read from Documents directory
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths objectAtIndex:0];
NSString *settingsFileName = [documentsDirectory stringByAppendingPathComponent:SETTINGS_FILE];
NSDictionary *settingsDic = nil;
NSFileManager *fileManager = [NSFileManager defaultManager];
BOOL fileExists = [fileManager fileExistsAtPath:settingsFileName];
if(fileExists) {
settingsDic = [NSDictionary dictionaryWithContentsOfFile:settingsFileName];
} else {
NSError *error = nil;
NSString *settingsBundleFilePath = [[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:SETTINGS_FILE];
BOOL success = [fileManager copyItemAtPath:settingsBundleFilePath toPath:settingsFileName error:&error];
if(success)
settingsDic = [NSDictionary dictionaryWithContentsOfFile:settingsFileName];
}
prefs = [NSUserDefaults standardUserDefaults];
if(!fileExists)
{
//subscription
[prefs setBool:YES forKey:@"Resubscribe"];
}
[prefs setObject:[settingsDic objectForKey:@"ADDRNAME"] forKey:@"ADDRNAME"];
if( updateDomain )
{
[prefs setObject:[settingsDic objectForKey:@"Domain"] forKey:@"Domain"];
}
[prefs setBool:[[settingsDic objectForKey:@"Https"] boolValue] forKey:@"Https"];
if( updateMBMHost )
{
[prefs setObject:[settingsDic objectForKey:@"Host"] forKey:@"Host"];
}
[prefs setObject:[settingsDic objectForKey:@"ServerNode"] forKey:@"ServerNode"];
[prefs removeObjectForKey:@"ULVersion"];
[prefs setObject:[settingsDic objectForKey:@"ULVersion"] forKey:@"ULVersion"];
forKey:@"ULDownloadOnly"];
[prefs setObject:[settingsDic objectForKey:@"AgentName"] forKey:@"AgentName"];
if ([[Settings getSettingsFileName] length] < 1) //This is the Line where it usually crashes"
[prefs setObject:[settingsDic objectForKey:@"SettingsFileName"] forKey:@"SettingsFileName"];
[prefs setObject:[settingsDic objectForKey:@"ScannerType"] forKey:@"ScannerType"];
NSString *supportEmailAddress = [settingsDic objectForKey:@"SupportEmailAddress"];
if( supportEmailAddress == nil )
{
supportEmailAddress = SUPPORT_EMAIL_ADDRESS;
}
[prefs setObject:supportEmailAddress forKey:@"SupportEmailAddress"];
//Don't set SyncCalContactsMode from plist since this will overide the user's selection
if([[settingsDic objectForKey:@"Instance"] length] > 1)
[prefs setObject:[settingsDic objectForKey:@"Instance"] forKey:@"Instance"];
else if ([[Settings getInstance] length] < 1)
[prefs setObject:@"Company" forKey:@"Instance"];
NSString *info = [NSString stringWithFormat:@"ULVersion = %@, ULDownloadOnly = %@ ", ([Settings getULVersion]==nil)?@"Version1":[Settings getULVersion], [Settings getULDownloadOnly]?@"YES":@"NO"];
[DebugLog writeDebugData:info];
}