Ant*_*Dev 7 iphone thread-safety nsuserdefaults ios
我知道文档说它是,并且我知道这个主题已经在讨论中,但我有一个有趣的堆栈结果,我不能得出其他任何东西,但这[NSUserDefaults standardUserDefaults]不是线程安全的.所以我会发布我的崩溃日志,并希望有人看到我不能的东西......
坠毁的线程
...
libdispatch.dylib 0x3ab53d67 _dispatch_client_callout + 23
libdispatch.dylib 0x3ab65e73 _dispatch_barrier_sync_f_invoke + 27
CoreFoundation 0x302b470d CFPreferencesAppSynchronize + 265
Foundation 0x30151b01 -[NSUserDefaults(NSUserDefaults) synchronize] + 25
MyApp 0x0009df8b -[AppDelegate applicationDidEnterBackground:] (AppDelegate.m:178)
...
MyApp 0x0005344b main (main.m:17)
MyApp 0x000533f8 start + 40
Run Code Online (Sandbox Code Playgroud)
一些其他线程
...
CoreFoundation 0x302bc13f _CFXPreferencesSetValue + 107
CoreFoundation 0x302bc039 CFPreferencesSetAppValue + 41
Foundation 0x30c76935 -[NSUserDefaults(NSUserDefaults) setObject:forKey:] + 61
MyApp 0x000b2e9d -[AppData parserDidEndDocument:] (AppData.m:1013)
...
Run Code Online (Sandbox Code Playgroud)
堆叠的部分已经被切掉并用"......"代替,因为它太长并且与主题无关.应用程序崩溃消息:
*集合<__ NSDictionaryM:0x15a04ae0>在枚举时发生了变异.....
代码:AppDelegate: - > crached thread ...
- (void)applicationDidEnterBackground:(UIApplication *)application
{
[[NSUserDefaults standardUserDefaults] synchronize];
}
Run Code Online (Sandbox Code Playgroud)
MyClass: - >第二个帖子:
-(void)parserDidEndDocument:(NSXMLParser *)parser {
...
[[NSUserDefaults standardUserDefaults] setObject:arr forKey:@"savedStations"];
[[NSUserDefaults standardUserDefaults] setObject:[NSDate date] forKey:@"lastUpdateDate"];
[[NSUserDefaults standardUserDefaults] setBool:YES forKey:@"alreadyLoaded"];
...
}
Run Code Online (Sandbox Code Playgroud)
我在其他几个案例中遇到此崩溃,它总是包含一些在一个线程中写入用户默认值并在其他崩溃的线程中同步...如果有人有其他解释我将非常非常...
| 归档时间: |
|
| 查看次数: |
4216 次 |
| 最近记录: |