objective-c – 断点指向“objc_autoreleaseNoPool”
所以我正在调试应用程序在其应用程序发布,并启用了一个通用断点为“所有异常”。从那以后,每次运行应用程序,控制台打印:
字面印刷3次。我不知道这是什么意思,但看起来不错。任何建议将不胜感激。 解决方法
新信息
我确定了我的问题在于创建一个swizzled自动释放方法。 我不建议这样做,除非你知道你在做什么,但这是我发现的。 + (void) load; //Method is called outside the original autorelease pool. + (void) initialize; // Method is called outside the original autorelease pool. NSThread创建自己的线程,被调用的方法应该被包装在一个自动释放池中。 使用“dispatch _…”命令时,Grand Central Dispatch会自动调整自动释放池。但是,当您手动分派时。您可能希望将其包装在自动释放池中。 此外,ARC不会让您知道自动释放将发生在池外。 因此,如果您使用ARC并且知道您将在自动释放池之外。并没有什么可以做到这一点。你会想避免所有方便的方法。 用这个。 [[NSString alloc] initWithFormat:@"%@",myObject]; 而不是这个 [NSString stringWithFormat:@"%@",myObject]; 这将允许弧系统保留和释放,但通过方便方法完成的底层自动释放将被跳过,因为您不会使用方便的方法。 希望有帮助。 原始答案 好的,我不觉得这个问题回答了足够的细节。 正在呈现的消息是 objc[1310]: Object 0x34f720 of class SimpleKeychain autoreleased with no pool in place - just leaking - break on objc_autoreleaseNoPool() to debug 调试器指出一个可能的断点,这将有助于您调试这种情况。现在这个断点真的没有帮助调试的情况。我认为重要的是要知道如何将这个断点添加到调试器中,所以我花费了时间来修补它(在清理互联网之后,找不到任何东西),直到我打破了这个错误。 这是令人讨厌的,所有错误的突破都没有抓住这一点,但这里是添加断点到调试器的步骤。 首先要做的是选择调试器的断点导航器 通过点击此选项卡 接下来,您将看到导航器窗格的底部,然后按加号按钮 这将允许您手动添加断点。 我选择了一个C断点,并在名称文本字段中输入消息名称。 在添加这个异常之后,它确实打破了。 然而,这可能是或者可能不是您作为客观c开发人员有用的。这突破了汇编代码。 不幸的是,它只在线程的调用堆栈上显示了这一点。 事实证明,自动释放问题是因为在dispatch_once调用中调用了一个自动释放类。进一步调查显示(无效)负荷;上课的方法是在其他任何事情之前被调用的。这通过call_load_methods函数完成,并且在main方法的线程之外。 为了纠正这一点,我只是在呼叫周围添加了自动释放池包装器。 另一个解决方案可能是在(void)加载中添加自动释放池;方法。但这对我的使用是足够的。 注意:我将此添加到这里的帖子,因为我不喜欢找到一个问题,无法找出所得到的答案的所有路径。如果调试器告诉你添加一个断点给列出的函数,那么应该有一些信息来获取这些信息。希望这将降低一些在那里试图找到这个答案的沮丧。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |