This看起来很有希望,但似乎不是重复的问题,因为它解决了 Swift 中的问题。
我正在完成一个现有的 Objective C 项目,但是 NSLog
当我更新到 Xcode 9 时消失了。所以我在 Xcode 中寻找一些设置,让我继续使用 NSLog
微调项目。
使用 Swift 和 Objective-C 应用程序日志记录的基本调试在 Xcode 9 中似乎已更改为 NSLog
消息不再出现在“调试”区域中。设置DEBUG=1 的窗口不再像Figure 2 The DEBUG preprocessor macro setting in an Xcode project. 了。
举个例子,我想使用Xcode9在调试区显示这个字符串消息。
NSString *outputData = @"This should show in Debug area";
NSLog( @"text: %@", outputData );
我研究了最新的文档here或 here但到目前为止,这没有帮助。可能还值得注意的是,以前运行项目时调试区域会自动打开。自从安装Xcode9
它不再那样做。
希望下面编辑中提供的额外信息能向我尚未查看的人提供建议。谢谢。
编辑 1
在控制台区域 - 即调试区域的右下部分 - 我选择了所有输出。所以我尝试使用调试器输出和目标输出,但仍然没有日志。
我在 Prefix.pch
中添加了这些语句文件
#ifndef DEBUG
#define NSLog(...) /* suppress NSLog when in release mode
#endif
当我运行代码时,问题导航器中出现以下内容。
Unused variable 'outputData'
编辑 2
在 Xcode9 中似乎有一个不同的地方可以设置 DEBUG=1(见下文)。
我使用几个 SO 帖子中建议的示例将 DEBUG 宏插入到 .pch 文件中 here , here , here (都很旧)和even here (确保将 MyLog 改回 NSLog)。在每种情况下,我都能够在问题导航器中报告相同的问题,但从未在调试控制台中报告过。解决了类似的问题(使用 Xcode5
)here通过将文件复制到一个新项目中,但我想避免这种情况。
到目前为止,我几乎完成的应用程序还没有处理统一日志记录试图解决的任何复杂问题。但我看了2016 WWDC video在统一日志记录上阅读它的幻灯片放映文件,搜索如何使用适当的 API 来做一些基本的事情的例子 - 打印 NSLog
进入控制台区域 - 就像我在安装之前所做的那样 Xcode9.
这可能是错误的做法。但我想不出更好的方法。
编辑 3
值得注意的是,当我使用Xcode9新建一个Objective C项目并运行上面的代码时,Console区域出现了字符串消息。
换句话说,使用 Xcode9,新的日志记录 API 确实与 NSLog,
一起工作但仅适用于新项目,不适用于使用早期版本的 Xcode 创建的项目。
启用 DEBUG 预处理器宏
最佳答案
与其将调试语句写入代码,不如尝试放入一个断点,右键单击它,然后选择“编辑断点”。你应该看到这个菜单:
从那里,您将单击“编辑断点”,然后您会看到:
从那里,您可以单击“操作”,您将看到此菜单:
您可以输入打印消息(例如:myMethodCalled
)或变量值(myIntValue = @myIntValue@
),或者您可以键入调试器命令以在该位置执行代码(例如:po dump(myArray)
)。
这种方法的缺点是断点并不总是“粘”在您最初放置它的代码行上。
关于ios - 如何使用 Xcode9 在 Debug 区域中显示此 Log 消息?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46397444/