Understanding Crashes and Crash Logs
Understanding Crashes and Crash Logs
WWDC 2018
Crashes Organizer
Xcode → Window → Organizer (Shift + Command + 6)
data:image/s3,"s3://crabby-images/31bc8/31bc8bd8efe499aca5c9adb7fafa77bd0fe98077" alt=""
Device Window
You can get logs from a device.
data:image/s3,"s3://crabby-images/eacdb/eacdb110d47b949debd27277a3f88c4892796219" alt=""
Automated testing
data:image/s3,"s3://crabby-images/58e75/58e75d6e9294ba6f52646402af203354c36f4585" alt=""
Symbolication
- Upload app symbols for server-side symbolication
- Keep your app archive for local symbolication
- Download debug symbols for bitcode apps
Analyzing Crash Logs
data:image/s3,"s3://crabby-images/78a27/78a279ca4e89b732625dc8f27d32e61ab15a5dcc" alt=""
data:image/s3,"s3://crabby-images/5394d/5394d0098b73a2cbc417b37168f34cd7634deb28" alt=""
data:image/s3,"s3://crabby-images/d9335/d933509276679f31f71d0b53a4ded6cba227b0e2" alt=""
Assertions and Preconditions
- Forced unwrap of an Optional that stores nil
- Out of bounds Array access
- Swift arithmetic overflow
- Uncaught exception
- Custom assertion in your code
Terminations by the Operating System
- Watchdog events (time out)
- Device overheated
- Memory exhaustion
- Invalid code signature
data:image/s3,"s3://crabby-images/28daa/28daa9b449c2f12581ea5bef43382a7cb871ee18" alt=""
Avoiding Launch Timeouts
- Test your app without the debugger
- Test your app on a real device
- Test your app on older hardware
Memory Errors
data:image/s3,"s3://crabby-images/20fa2/20fa2777cf0f2a494182f4797e4d48aa90dde36e" alt=""
Object life cycle
Dealloc → Freed object → Rotate
data:image/s3,"s3://crabby-images/06252/06252b7964beb137844f060bf16c21a82d64d32e" alt=""
Crash Log Analysis
- Understand the crash reason
- Examine the crashed thread’s stack trace
- Look for more clues in bad address and disassembly 👍
data:image/s3,"s3://crabby-images/fe45f/fe45fcd4e66027fa256bcef4c956583d6df32567" alt=""
Common Memory Error Symptoms
data:image/s3,"s3://crabby-images/54374/543743e9cb657491e401696d5ceb234a0902325c" alt=""
Crash Analysis Tips
- Look at code other than the line that crashed
- Look at thread stack traces other than the crashed thread
- Look at more than one crash log
- Use Address Sanitizer and Zombies to reproduce memory errors
Multithreading Issues
Use theThread Sanitizer to fix multi-threading issues
data:image/s3,"s3://crabby-images/7520a/7520aaaccc4de8aab4def764aa429c50b7813e42" alt=""
Demo
data:image/s3,"s3://crabby-images/a474e/a474ebc0b875989121fb84c16a5f35e7376b6fad" alt=""
Tips
Use the thread name
data:image/s3,"s3://crabby-images/bf2c3/bf2c3a1a024f8eba50d9cd4e692dffdfd6f988da" alt=""