为什么推荐你使用 Xcode 15 的结构化打印?

前言

在日常的开发中,我们需要在 Xcode 控制台打印大量的日志用于调试,这些日志慢慢积累的多了之后可能会变得不堪重负,慢慢的甚至会恶化到不可用的状态。

在 Xcode 15 中,Apple 的开发人员尝试解决这个问题,在 Xcode 的控制台终于支持过滤功能了,今天来讲讲这个新功能。

Logger 类型

日志记录的 API 在 iOS 14 中引入了 Logger 类型,它可以很方便的记录 log,下面是如何使用 Logger 类型的示例:

css 复制代码
let logger = Logger(subsystem: "my_system", category: "my_category")
logger.log("这是一个 Log 信息")
logger.info("这是一个 info 信息")
logger.warning("这是一个 warning 信息")
logger.debug("这是一个 Debug 信息")
logger.error("这是一个 Error 信息")
logger.fault("这是一个 fault 信息")

在控制台看到的效果:

一些高级用法

1. 查看 log 详细信息

在控制台中,如果我们想检查单个日志行,那么我们可以单击这一行日志并按空格键,这将打开一个新的信息窗口,窗口中会展示跟这个日志相关的详细信息:

这里可以看到这条日志的类型、时间、Subsystem、Category 以及调用方法等等。

2. 直接在 log 中显示详细信息

如果觉得每次点击 + 空格比较麻烦,还可以在下边的 MetaData Options 按钮中打开要显示的信息:

然后就可以在每条日志上看到对应的信息了:

3. 快捷跳转 log 所在的源代码中

把鼠标在某条日志上停留一下,就会在这条日志的右下角出现一个提示,标记这个 log 是在哪个文件的哪一行打印的,点击右侧的箭头可直接跳转到对应的代码中:

4. 日志过滤

在控制台的右下角有个 filter 的输入框,可以在这个输入框中进行日志的过滤,比如我只想看 my_category 这个类型的日志,那么就可以在输入框中输入 my_category 根据提示来增加过滤:

可过滤的条件有很多,可以点击左侧的按钮查看:

继续在输入框中输入,还可以增加其他的过滤条件:

这个功能可以说非常强大,而且非常方便了,如果你已经升级了 Xcode 15,强烈推荐你的项目在开发时使用起来。

这里每天分享一个 iOS 的新知识,快来关注我吧

本文同步自微信公众号 "iOS新知",每天准时分享一个新知识,这里只是同步,想要及时学到就来关注我吧!

相关推荐
hellojackjiang201137 分钟前
全面适配iOS 26液态玻璃,基于开源IM即时通讯框架MobileIMSDK:RainbowChat-iOS端v10.2发布
ios·网络编程·即时通讯·im开发·rainbowchat
非专业程序员Ping4 小时前
一文读懂字符、字形、字体
ios·swift·font
2501_915921435 小时前
iOS 应用代上架流程,多工具组合与使用 开心上架 跨平台自动化上传指南
android·ios·小程序·uni-app·自动化·cocoa·iphone
日日行不惧千万里5 小时前
2025最新仿默往 IM 即时通讯系统源码(PC + Web + iOS + Android)完整版发布!
android·ios
歪歪1005 小时前
React Native开发Android&IOS流程完整指南
android·开发语言·前端·react native·ios·前端框架
阿里超级工程师6 小时前
ios云打包证书申请不需要苹果电脑也是可以的
ios·证书·云打包
2501_915918418 小时前
iOS 混淆与 IPA 加固一页式行动手册(多工具组合实战 源码成品运维闭环)
android·运维·ios·小程序·uni-app·iphone·webview
东坡肘子9 小时前
去 Apple Store 修手机 | 肘子的 Swift 周报 #0107
swiftui·swift·apple
RollingPin11 小时前
iOS八股文之 网络
网络·网络协议·ios·https·udp·tcp·ios面试
彩旗工作室1 天前
将iOS/macOS应用上架至App Store
macos·ios·应用商店·appstore