iOS15之后苹果崩溃日志解析方法

iOS15之后苹果崩溃日志解析方法

背景

iOS 15之后,iPhone 崩溃日志崩溃之后,崩溃日志的组织格式有变化了,不再是之前的行式表示,而是JSON格式记录。示例如下。

获取解析脚本

苹果在Xcode13的工具里提供了新的脚本,解析iOS15之后的崩溃日志,脚本名字为CrashSymbolicator.py,可以在目录/Applications/Xcode.app/Contents/SharedFrameworks/CoreSymbolicationDT.framework/Versions/A/Resources下获取脚本。

解析方法

因为苹果是python3写的脚本,所以需要使用python3调用脚本,简单的方法命令为

python3 /Applications/Xcode.app/Contents/SharedFrameworks/CoreSymbolicationDT.framework/Versions/A/Resources/CrashSymbolicator.py 要解析的崩溃日志 -d dSYM所在路径 -o 解析后的日志地址

如图所示:

command.png

PS: 请注意,解析之后的结果也是json格式的。

魔改脚本

因为脚本是在Xcode里面的,如果要直接使用,需要在脚本首行增加如下逻辑如下


import sys

sys.path.append("/Applications/Xcode.app/Contents/SharedFrameworks/CoreSymbolicationDT.framework/Versions/A/Resources/")

如果有人想直接获取,请移步下载

#具体参数说明

  1. “-d”,”–dsym":后面需要加上dSYM文件所在的路径

  2. “-s”,"–search-dir":后面需要加上额外的系统符号文件所在的目录

  3. “-o”,,"–output":后面需要加上解析后的崩溃日志保存地址,默认是终端输出

  4. “-p”, “–pretty”:崩溃日志格式化,默认不需要

  5. “-w”, “–workers”:开启多进程符号化崩溃日志,默认不开启

  6. ”–no-inlines",:解析的时候需要显示内联函数,默认不显示

  7. “–no-source-info":解析的时候不显示函数的文件和行数,默认显示

  8. ”–only-missing":只回溯崩溃堆栈,默认回溯所有符号

  9. “–no-system-frameworks”:系统符号不解析,默认解析

  10. ”-v","–verbose":输出解析过程详细日志,默认不输出

  11. “crash_log”:要解析的崩溃日志路径,或者等待终端输入

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
iOS 15 中,可以使用 AVFoundation 中的 AVAssetReader 来解析视频每帧,然后将每帧呈现到 SwiftUI 中的 View 上。 首先,您需要创建一个 AVAssetReader 对象,并为其提供一个 AVAsset 对象。然后,创建一个 AVAssetReaderTrackOutput 对象,并将其添加到 AVAssetReader 上,以便从视频中读取帧。 接下来,您可以使用 AVAssetReaderTrackOutput 的 copyNextSampleBuffer() 方法来获取视频中的下一帧。将返回的 CMSampleBuffer 转换为 CGImage,然后将其呈现到 SwiftUI View 上的 UIImageView 中。 以下是一个简单的示例代码,它演示了如何在 SwiftUI 中解析视频每帧: ```swift import SwiftUI import AVFoundation struct VideoPlayerView: View { let videoURL: URL var body: some View { VideoPlayer(url: videoURL) .onAppear { let asset = AVAsset(url: videoURL) let reader = try! AVAssetReader(asset: asset) let track = asset.tracks(withMediaType: .video)[0] let output = AVAssetReaderTrackOutput(track: track, outputSettings: nil) reader.add(output) reader.startReading() while let sampleBuffer = output.copyNextSampleBuffer() { let imageBuffer = CMSampleBufferGetImageBuffer(sampleBuffer)! let ciImage = CIImage(cvPixelBuffer: imageBuffer) let cgImage = CIContext().createCGImage(ciImage, from: ciImage.extent)! let uiImage = UIImage(cgImage: cgImage) let imageView = UIImageView(image: uiImage) // Do something with imageView CMSampleBufferInvalidate(sampleBuffer) } } } } ``` 注意,此示例仅演示了如何解析视频每帧,并将其呈现到 UIImageView 中。您需要根据自己的需求适当地调整代码,以便将每帧呈现到您的 SwiftUI View 上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值