加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

objective-c – 断点指向“objc_autoreleaseNoPool”

发布时间:2020-12-15 01:56:22 所属栏目:百科 来源:网络整理
导读:所以我正在调试应用程序在其应用程序发布,并启用了一个通用断点为“所有异常”。从那以后,每次运行应用程序,控制台打印: Catchpoint 2 (throw)Pending breakpoint 1 – “objc_exception_throw” resolved objc[11765]: Object 0x8f18ff0 of class __NSC
所以我正在调试应用程序在其应用程序发布,并启用了一个通用断点为“所有异常”。从那以后,每次运行应用程序,控制台打印:

Catchpoint 2 (throw)Pending breakpoint 1 – “objc_exception_throw” resolved

objc[11765]: Object 0x8f18ff0 of class __NSCFLocale autoreleased with no pool in place – just leaking – break on objc_autoreleaseNoPool() to debug

objc[11765]: Object 0x8f190a0 of class __NSCFNumber autoreleased with no pool in place – just leaking – break on objc_autoreleaseNoPool() to debug

objc[11765]: Object 0x8f1fef0 of class __NSCFLocale autoreleased with no pool in place – just leaking – break on objc_autoreleaseNoPool() to debug

字面印刷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)加载中添加自动释放池;方法。但这对我的使用是足够的。

注意:我将此添加到这里的帖子,因为我不喜欢找到一个问题,无法找出所得到的答案的所有路径。如果调试器告诉你添加一个断点给列出的函数,那么应该有一些信息来获取这些信息。希望这将降低一些在那里试图找到这个答案的沮丧。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读