iOS 底层原理39:Instruments系列(一)Instruments介绍

简介: iOS 底层原理39:Instruments系列(一)Instruments介绍

前言


通常程序运行时常见的错误大致分为两类


  • 用户使用引起的外部错误,例如缺少参数、参数错误等
  • 程序运行时产生的内部错误,例如内存溢出、空指针、以0做除数等


针对第一种外部错误,一般是不可控的,因为用户的行为是随机的,所以一般只能采取相应的预防措施,尽最大程度去避免这类问题


针对第二种内部错误,可以通过一些工具及时的找出问题并修正。这里就不得不提及Xcode自带的检测调试工具Instruments了。


介绍


Instruments是一个非常灵活、且强大的工具,可以进行性能分析、动态追踪、代码分析等,让我们对程序的内部运行更加了解。主要可以做以下事情:


  • 用于动态调追踪和分析OS X和iOS的代码的性能分析和测试工具
  • 支持多线程调试
  • 支持录制和回放图形界面的操作过程
  • 追踪代码中的问题(甚至是难以复现的)
  • 分析程序的性能
  • 实现程序的自动化测试
  • 部分实现程序的压力测试
  • 执行系统级别的通用问题最终调试


打开方式有以下三种:


  • 快捷键:CMD + I(对应小写的i)
  • Xcode -> Open Developer Tool -> Instruments
  • 项目 -> Product -> Profile


Instruments具体的界面如下所示

image.png

  • Blank:创建一个空的模板,可以自定义添加各种工具
  • Activity Monitor:跟踪整个系统的活动,包括 CPU、内存、网络和磁盘。默认情况下,活动监视器模板不会在时间线窗格中显示网络或磁盘活动
  • Allocations:使用Allocations和VM Tracker工具来测量应用程序中的常规和虚拟内存使用情况
  • Animation Hitches:用于检测滚动和动画问题,以帮助您可视化和研究应用程序的图形管道。通俗来讲就是检测界面流畅度,是否有卡顿情况
  • App Launch:使用 5 秒时间配置文件和线程状态跟踪调整应用程序启动性能
  • Core Data:可以检测应用程序中数据的存储交互,例如数据提取、缓存缺失和存储等
  • CPU Counters:收集使用时间或基于事件的抽样方法的性能监控计数器(PMC)事件,使用 Counters 工具来跟踪 PMC 事件。
  • CPU Profiler:用于分析 CPU 工作负载的基于周期的分析器,使用硬件性能监控中断(PMI)来提供更稳定的测量,无论代码是在性能 CPU 还是效率 CPU 上运行
  • File Activity:用于检查系统文件的使用情况,可以检查文件的打开、关闭、读和写操作,同时也可以检测文件系统本身的改变,包括权限和所有权发生的改变。
  • Game Performance:用于检测游戏性能和帧率
  • Leaks:用来检测内存的泄漏
  • Logging:来自统一日志系统的日志和路标的可视化。用于导入日志存档文件的默认模板
  • Metal System Trace:是apple 2014年在ios平台上推出的高效底层的3D图形API,它通过减少驱动层的API调用CPU的消耗提高渲染效率。
  • Network:使用连接工具来分析iOS应用程序的TCP/IP和UDP/IP连接
  • SceneKit:检测的app是使用了screenKit。用于确定每一帧的工作类型,例如动画、物理、场景剔除和渲染。
  • SwiftUI:SwiftUI分析工具,用于跟踪视图类型的 .body 调用、动态视图属性随时间的更新以及识别慢帧
  • System Trace:操作系统中事件发生的全视图。了解线程是如何跨 CPU 调度的,并了解系统调用和虚拟内存故障如何影响应用程序的性能
  • Time Profiler:使用时间分析器工具对系统CPU上运行的进程执行低开销、基于时间的采样。随着时间的推移,多核和线程的使用效率越高,应用程序的性能就越好。时间分析器工具中的CPU和线程策略显示了应用程序对内核和线程的利用程度。
  • Zombies:使用分配工具来测量应用程序中的一般内存使用情况,重点是检测过度释放的“zombie”对象,即在释放后调用的对象,这些对象不再存在。


其中常用的是以下几种,后续会分别介绍如何使用及自定义


  • Allocation
  • Animation Hitches
  • App Launch
  • Leaks
  • Network
  • Time Profiler:
  • Zombies


相关文章
|
2月前
|
存储 运维 安全
iOS加固原理与常见措施:保护移动应用程序安全的利器
iOS加固原理与常见措施:保护移动应用程序安全的利器
31 0
|
4月前
|
存储 运维 安全
iOS加固原理与常见措施:保护移动应用程序安全的利器
iOS加固原理与常见措施:保护移动应用程序安全的利器
41 0
|
8月前
|
C语言 索引
09-iOS之load和initialize底层调用原理分析
09-iOS之load和initialize底层调用原理分析
60 0
|
3月前
|
安全 前端开发 数据安全/隐私保护
【教程】 iOS混淆加固原理篇
本文介绍了iOS应用程序混淆加固的缘由,编译过程以及常见的加固类型和逆向工具。详细讨论了字符串混淆、类名、方法名混淆、程序结构混淆加密等加固类型,并介绍了常见的逆向工具和代码虚拟化技术。
|
4月前
|
安全 算法 前端开发
【完整版教程】iOS混淆加固原理篇
在iOS开发中,应用程序的安全性和保护显得尤为重要。由于iOS系统的开放性,一些逆向工具可以轻松地对应用程序进行反编译和分析,从而导致应用程序源代码、算法和敏感信息的泄露。为了保护应用程序的安全性,我们需要对应用程序进行混淆加固。本文将介绍iOS混淆加固的原理和常见的加固类型。
|
4月前
|
JSON 安全 数据安全/隐私保护
​iOS Class Guard github用法、工作原理和安装详解及使用经验总结
​iOS Class Guard github用法、工作原理和安装详解及使用经验总结
20 0
|
4月前
|
安全 数据安全/隐私保护 iOS开发
【iOS开发】iOS App的加固保护原理:使用ipaguard混淆加固
【iOS开发】iOS App的加固保护原理:使用ipaguard混淆加固
51 0
|
5月前
|
JSON 安全 数据安全/隐私保护
​iOS Class Guard github用法、工作原理和安装详解及使用经验总结
iOS Class Guard是一个用于OC类、协议、属性和方法名混淆的命令行工具。它是class-dump的扩展。这个工具会生成一个symbol table,这个table在编译期间会包含进工程中。iOS-Class-Guard能有效的隐藏绝大多数的类、协议、方法、属性和 实例变量 名。iOS-Class-Guard不是应用安全的最终解决方案,但是它绝对能让攻击者更难读懂你的程序。iOS-Class-Guard会加大代码分析和runtime检查的难度,这个工具可以认为是一个简单基础的混淆方法。由于OC的架构决定了iOS应用程序的剖析相当简单,check out一下链接就知晓了:
|
6月前
|
安全 数据安全/隐私保护 iOS开发
【iOS开发】iOS App的加固保护原理:使用ipaguard混淆加固 摘要
随着智能手机的普及,越来越多的用户使用iOS设备来处理日常任务,因此iOS应用程序的安全性变得越来越重要。为了防止应用程序被攻击或破解,开发人员需要采用一些保护措施来加固应用程序。本文将介绍一种使用ipaguard混淆加固的方法来保护iOS应用的安全。
|
6月前
|
运维 安全 数据安全/隐私保护
iOS加固原理与常见措施:保护移动应用程序安全的利器
随着移动应用的普及和用户对数据安全的关注度提高,iOS加固成为了很多开发者和企业的必备工具。那么,iOS加固是如何保护应用程序的安全性的呢? iOS加固是指对OS应用程序进行一系列的安全措施,以提高其抗逆向工程、反编译和破解的能力。下面将介绍iOS加固的原理和常见的加固措施。
iOS加固原理与常见措施:保护移动应用程序安全的利器