当使用Xcode 8+并创建一个新的空白项目时,运行应用程序时会出现以下日志:

2016-06-13 16:33:34.406093 TestiOS10[8209:100611] bundleid: com.appc.TestiOS10, enable_level: 0, persist_level: 0, propagate_with_activity: 0
2016-06-13 16:33:34.406323 TestiOS10[8209:100607] Created DB, header sequence number = 248
2016-06-13 16:33:34.409564 TestiOS10[8209:100611] subsystem: com.apple.UIKit, category: HIDEvents, enable_level: 0, persist_level: 0, default_ttl: 0, info_ttl: 0, debug_ttl: 0, generate_symptoms: 0, enable_oversize: 0, privacy_setting: 0
2016-06-13 16:33:34.504117 TestiOS10[8209:100607] Created DB, header sequence number = 248
2016-06-13 16:33:34.548023 TestiOS10[8209:100607] subsystem: com.apple.BaseBoard, category: MachPort, enable_level: 0, persist_level: 0, default_ttl: 0, info_ttl: 0, debug_ttl: 0, generate_symptoms: 0, enable_oversize: 0, privacy_setting: 0
2016-06-13 16:33:34.568458 TestiOS10[8209:100608] subsystem: com.apple.FrontBoard, category: Common, enable_level: 0, persist_level: 0, default_ttl: 0, info_ttl: 0, debug_ttl: 0, generate_symptoms: 0, enable_oversize: 0, privacy_setting: 0

也许有人已经找到了这个的配置?


当前回答

我读了所有的解决方案,到目前为止没有任何工作,我在写这个响应的时候使用XCODE 12.5,这是在调试器中看到的最讨厌的事情,有这么一堆/泛滥的不想要的消息。

我所做的解决方案比大多数复杂的解决方案要简单得多,以下是我解决这个烦人问题的方法:

不需要使用任何环境变量等,否则使用这些建议的前一篇文章将禁用NSLOG输出,这不是你想要的在这种情况下。 我确保我所有的NSLOG将包含一个字符串,我将在以后监视,例如:

以前我经常做:

NSLog(@"Hello World");

现在,我想:

NSLog(@"[Admin]: Hello World");

而“[Admin]”是我的程序名(或除[Admin]以外的任何字符串)。

(可选步骤)或(更容易),我写了一个函数来通道(好吧;代理)NSLog到另一个全局函数“日志”,而所有我的日志将去该函数,然后日志函数将追加“[Admin]”字符串到原始日志字符串,还添加日志时间和其他项目,我需要等(类似于WebLogic或任何其他JAVA日志),这确保所有日志将遵循一个标准。 …这是价值百万美元的核武器:

现在,进入你的调试器窗口,在底部你会看到一个“搜索”窗口,而它说“过滤器”,输入你的字符串(例如;“[Admin]”),按ENTER键,任务完成。

这样,你只会看到你喜欢的线条,

当你想过滤掉其他组件时也很有用,例如,对于网络通信,我使用更多的字符串,我可以稍后过滤。

换句话说,烦人的日志行与你的应用程序无关,但你选择不看到他们使用上述命令,我希望解决这个问题。

希望大家都能度过美好的一天。

H

其他回答

这与Xcode 8 Beta发布说明中发现的一个已知日志问题有关(也在WWDC上询问了一位工程师)。

在Watch模拟器中调试WatchOS应用程序时,操作系统可能会产生过多的 大量无用的日志记录。(26652255)

目前没有可用的解决方案,你必须等待新版本的Xcode。

编辑7/5/16:这应该是修复了Xcode 8 Beta 2:

在Xcode 8 beta 2 - IDE中解决 调试 当在模拟器上调试应用程序时,日志是可见的。(26457535)

Xcode 8 Beta 2发布说明

这个解决方案对我来说很有效:

在模拟器中运行应用程序 打开系统日志(⌘+ /)

这将转储出所有的调试数据和nslog。

过滤你的NSLog语句:

在每一个前加上一个符号,例如:NSLog(@"^测试日志") 使用右上方的搜索框过滤结果,在上面的例子中是“^”

这是你应该得到的:

我的解决方案是在断点中使用调试器命令和/或日志消息。

并将控制台的输出从所有输出更改为调试器输出

请看下面的步骤。

选择Product => Scheme =>编辑Scheme或使用快捷方式:CMD + < 从左边选择Run选项。 在“环境变量”一节中,添加变量OS_ACTIVITY_MODE = disable

欲了解更多信息,请找到下面的GIF表示。

在xcode 8.1(测试版本8.1 beta版(8T46g))中,这不再是一个问题。您可以从方案中删除OS_ACTIVITY_MODE环境变量。

https://developer.apple.com/go/?id=xcode-8.1-beta-rn

调试 Xcode调试控制台不再显示来自系统的额外日志 在模拟器中调试应用程序时使用框架。(26652255, 27331147)