通常,如果您在NSOperationQueue上生成后台线程或运行NSOperation,则需要为该线程或操作创建NSAutoreleasePool,因为默认情况下不存在.
相同的规则是否适用于放置在Grand Central Dispatch队列中并将在非主线程上运行的块?也就是说,您是否需要在每个块中创建一个NSAutoreleasePool,并将其分派给主队列以外的任何其他块?
在我的有限测试中,我没有看到通常在后台线程或NSOperations中看到的自动释放对象的控制台警告.但是,我似乎无法找到关于此的明确文档,所以我想知道是否有人可以指出这里的陈述.
我正试图在iPad上解析一个非常大的json-File.文件大小将在50到100 MB之间变化(有一个初始文件,每月将有一个新的完整数据集,将被下载,解析并保存到coredata中)
我正在为一家公司构建这个应用程序作为企业解决方案 - json文件包含敏感的customerdata,它需要在ipad本地保存,以便它甚至可以脱机工作.当文件低于20mb时它工作,但现在数据集变得更大,我真的需要解析它.我在解析过程中收到内存警告,在第三次警告后它就崩溃了.我有几个不同的核心数据实体,我只是设置来自json文件的所有值(当应用程序第一次启动时),一切都完成后,我正在做[context save].
我希望有人能就如何处理如此庞大的文件给我一些建议.我正在考虑将json文件拆分为几个较小的json文件,并且可能在多个线程中解析它们,但我不知道这是否是正确的方法.我想一个大问题是整个文件都被保存在内存中 - 也许有某种方法可以将它"流式化"到内存中或类似的东西?
我正在使用JSONKit(https://github.com/johnezang/JSONKit)来解析文件,因为我已经读过它是最快的一个(可能有一个较慢的一个在内存上更容易?).
提前致谢.