askill
performance-profiling

performance-profilingSafety 100Repository

Guide performance profiling with Instruments, diagnose hangs, memory issues, slow launches, and energy drain. Use when reviewing app performance or investigating specific bottlenecks.

44 stars
1.2k downloads
Updated 2/20/2026

Package Files

Loading files...
SKILL.md

Performance Profiling

Systematic guide for profiling Apple platform apps using Instruments, Xcode diagnostics, and MetricKit. Covers CPU, memory, launch time, and energy analysis with actionable fix patterns.

When This Skill Activates

Use this skill when the user:

  • Reports app hangs, stutters, or dropped frames
  • Needs to profile CPU usage or find hot code paths
  • Has memory leaks, high memory usage, or OOM crashes
  • Wants to optimize app launch time
  • Needs to reduce battery/energy impact
  • Asks about Instruments, Time Profiler, Allocations, or Leaks
  • Wants to add os_signpost or performance measurement to code
  • Is preparing for App Store review and needs performance validation

Decision Tree

What performance problem are you investigating?
│
├─ App hangs / stutters / dropped frames / slow UI
│  └─ Read time-profiler.md
│
├─ High memory / leaks / OOM crashes / growing footprint
│  └─ Read memory-profiling.md
│
├─ Slow app launch / time to first frame
│  └─ Read launch-optimization.md
│
├─ Battery drain / thermal throttling / background energy
│  └─ Read energy-diagnostics.md
│
├─ General "app feels slow" (unknown cause)
│  └─ Start with time-profiler.md, then memory-profiling.md
│
└─ Pre-release performance audit
   └─ Read ALL reference files, use Review Checklist below

Quick Reference

ProblemInstrument / ToolKey MetricReference
UI hangs > 250msTime Profiler + HangsHang duration, main thread stacktime-profiler.md
High CPU usageTime ProfilerCPU % by function, call tree weighttime-profiler.md
Memory leakLeaks + Memory GraphLeaked bytes, retain cycle pathsmemory-profiling.md
Memory growthAllocationsLive bytes, generation analysismemory-profiling.md
Slow launchApp LaunchTime to first frame (pre-main + post-main)launch-optimization.md
Battery drainEnergy LogEnergy Impact score, CPU/GPU/networkenergy-diagnostics.md
Thermal issuesActivity MonitorThermal state transitionsenergy-diagnostics.md
Network wasteNetwork profilerRedundant fetches, large payloadsenergy-diagnostics.md

Process

1. Identify the Problem Category

Ask the user or inspect their description to classify the issue:

  • Responsiveness: Hangs, stutters, animation drops
  • Memory: Leaks, growth, OOM crashes
  • Launch: Slow cold/warm start
  • Energy: Battery drain, thermal throttling

2. Read the Appropriate Reference File

Each file contains:

  • Which Instruments template to use
  • Step-by-step profiling workflow
  • How to interpret results
  • Common fix patterns with code examples

3. Profile on Real Hardware

Always remind users:

  • Profile on device, not Simulator (Simulator uses host CPU/memory)
  • Use Release build configuration (optimizations change behavior)
  • Profile with representative data (empty databases hide real perf)
  • Close other apps to reduce noise

4. Apply Fixes and Verify

After identifying bottlenecks:

  • Apply targeted fix from the reference file
  • Re-profile to confirm improvement
  • Add os_signpost markers for ongoing monitoring

Xcode Diagnostic Settings

Recommend enabling these in Scheme > Run > Diagnostics:

SettingWhat It Catches
Main Thread CheckerUI work off main thread
Thread SanitizerData races
Address SanitizerBuffer overflows, use-after-free
Malloc Stack LoggingMemory allocation call stacks
Zombie ObjectsMessages to deallocated objects

MetricKit Integration

For production monitoring, recommend MetricKit:

import MetricKit

final class PerformanceReporter: NSObject, MXMetricManagerSubscriber {
    func startCollecting() {
        MXMetricManager.shared.add(self)
    }

    func didReceive(_ payloads: [MXMetricPayload]) {
        for payload in payloads {
            // Launch time
            if let launch = payload.applicationLaunchMetrics {
                log("Resume time: \(launch.histogrammedResumeTime)")
            }
            // Hang rate
            if let responsiveness = payload.applicationResponsivenessMetrics {
                log("Hang time: \(responsiveness.histogrammedApplicationHangTime)")
            }
            // Memory
            if let memory = payload.memoryMetrics {
                log("Peak memory: \(memory.peakMemoryUsage)")
            }
        }
    }

    func didReceive(_ payloads: [MXDiagnosticPayload]) {
        for payload in payloads {
            if let hangs = payload.hangDiagnostics {
                for hang in hangs {
                    log("Hang: \(hang.callStackTree)")
                }
            }
        }
    }
}

Review Checklist

Responsiveness

  • No synchronous work on main thread > 100ms
  • No file I/O or network calls on main thread
  • Core Data / SwiftData fetches use background contexts for large queries
  • Images decoded off main thread (use .preparingThumbnail or async decoding)
  • @MainActor only on code that truly needs UI access

Memory

  • No retain cycles (check delegate patterns, closures with self)
  • Large resources freed when not visible (images, caches)
  • Collections don't grow unbounded (capped caches, pagination)
  • autoreleasepool used in tight loops creating ObjC objects

Launch Time

  • No heavy work in init() of @main App struct
  • Deferred non-essential initialization (analytics, prefetch)
  • Minimal dynamic frameworks (prefer static linking)
  • No synchronous network calls at launch

Energy

  • Background tasks use BGProcessingTaskRequest appropriately
  • Location accuracy matches actual need (not always .best)
  • Timers use tolerance to allow coalescing
  • Network requests batched where possible

References

Install

Download ZIP
Requires askill CLI v1.0+

AI Quality Score

92/100Analyzed 2/24/2026

Excellent skill for Apple platform performance profiling. Comprehensive decision tree, structured process steps, reference tables, Xcode diagnostic settings, MetricKit code examples, and detailed review checklist. Clear activation triggers and highly actionable. Slight mismatch between tags (CI/CD, GitHub Actions) and actual content (Instruments profiling), but quality is high.

100
92
90
95
90

Metadata

Licenseunknown
Version-
Updated2/20/2026
Publisherrshankras

Tags

apici-cdgithub-actionsobservability