Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Session 409 - Learning Instruments
Search
wwdcman
August 27, 2012
1
130
Session 409 - Learning Instruments
wwdcman
August 27, 2012
Tweet
Share
More Decks by wwdcman
See All by wwdcman
Session 412 - Debugging with Xcode
wwdcman
0
110
Session 404 - Building from the Command Line with Xcode
wwdcman
0
140
Session 306 - Integrating With Facebook, Twitter and Sina Weibo
wwdcman
0
200
Session 230 - Advanced Attributed Strings for iOS
wwdcman
0
75
Session 228 - Best Practices for Mastering Auto Layout
wwdcman
0
1.5k
Session 227 - Using iCloud with Core Data
wwdcman
0
280
Session 226 - Core Text and Fonts
wwdcman
0
83
Session 225 - Up and Running: Making a Great Impression with Every Launch
wwdcman
0
100
Session 224 - Using iCloud with NSDocument
wwdcman
0
310
Featured
See All Featured
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
232
17k
Reflections from 52 weeks, 52 projects
jeffersonlam
347
20k
Documentation Writing (for coders)
carmenintech
66
4.5k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
44
9.3k
Fashionably flexible responsive web design (full day workshop)
malarkey
405
66k
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
PRO
10
810
Fantastic passwords and where to find them - at NoRuKo
philnash
50
2.9k
Writing Fast Ruby
sferik
628
61k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
28
2.1k
XXLCSS - How to scale CSS and keep your sanity
sugarenia
248
1.3M
Unsuck your backbone
ammeep
669
57k
Building Adaptive Systems
keathley
38
2.3k
Transcript
These are confidential sessions—please refrain from streaming, blogging, or taking
pictures Profiling your App Session 409 Learning Instruments David M. O’Rourke Performance Tools Engineering Manager
What You’ll Learn Today
What You’ll Learn Today •Elements of performance
What You’ll Learn Today •Elements of performance •Methodology to improve
performance
What You’ll Learn Today •Elements of performance •Methodology to improve
performance •Instruments tour
What You’ll Learn Today •Elements of performance •Methodology to improve
performance •Instruments tour •iOS App optimization demonstrations
What Is Performance?
None
None
None
None
None
None
"Crashes all the time" "Crashes all the time"
None
None
None
Performance Is a Feature of Your App
Performance Is a Feature of Your App •Xcode to author/build
your app
Performance Is a Feature of Your App •Xcode to author/build
your app •Interface Builder to design your app
Performance Is a Feature of Your App •Xcode to author/build
your app •Interface Builder to design your app •Instruments to profile your app ▪ Optimize performance ▪ Reduces crashes and terminations ▪ Can improve power usage
Performance Profile Process
Debug Process
Debug Process Reproduce the problem
Debug Process Reproduce the problem Debug and inspect logs
Debug Process Reproduce the problem Form a hypothesis Debug and
inspect logs
Debug Process Reproduce the problem Form a hypothesis Make a
change Debug and inspect logs
Debug Process Reproduce the problem Form a hypothesis Make a
change Debug and inspect logs
Profile Process
Profile Process Reproduce the problem
Profile Process Reproduce the problem Profile with tools
Profile Process Form a hypothesis Reproduce the problem Profile with
tools
Profile Process Form a hypothesis Make a change Reproduce the
problem Profile with tools
Profile Process Form a hypothesis Make a change Reproduce the
problem Profile with tools
Where Can I Find Instruments?
Where Can I Find Instruments?
How Do I Access Instruments?
How Do I Access Instruments?
How Do I Access Instruments?
How Do I Access Instruments? •Pro Tip ▪ Right-click and
choose Keep in Dock
Instruments Tour
Document Model and Templates
Tour
Tour Toolbar
Tour Strategies
Tour Timeline
Tour Details
Tour Extended Details
Toolbar
Toolbar
Toolbar
Toolbar Target menu
Toolbar Target menu
Toolbar
Toolbar
Toolbar
Toolbar
Toolbar
Toolbar
Timeline Instrument strategy
Timeline Threads strategy
Timeline CPU strategy
Timeline and Filtering System Trace
Detail Pane Call Tree
Detail Pane Call Tree
Detail Pane Sample List
Detail Pane Source code
Detail Pane Source code
Detail Pane Disassembly
Detail Pane System Calls
Detail Pane Activity summary
Instruments
Demo Time Profiler example Joe Grzywacz Performance Tools Engineering
Use Call Tree
Use Call Tree
Use Thread Strategy
Use Thread Strategy
Use CPU Strategy
Demo Memory profiling example Victor Hernandez Performance Tools Engineering
Use Cycles and Roots
Use Allocations
Use Allocations
Closing Thoughts…
Profile Process
Profile Process Reproduce the problem
Profile Process Reproduce the problem Profile with tools
Profile Process Form a hypothesis Reproduce the problem Profile with
tools
Profile Process Form a hypothesis Make a change Reproduce the
problem Profile with tools
Profile Process Form a hypothesis Make a change Reproduce the
problem Profile with tools
Instruments Templates Used
Instruments Templates Used 3 Improvements 2 Improvements
Can Profile Virtually Anything
Can Profile Virtually Anything
"Fantastic and Fast" "Fantastic and Fast"
"Must buy this app" "Must buy this app"
None
None
None
More Information Michael Jurewitz Developer Tools Evangelist
[email protected]
Instruments Documentation
Instruments User Guide (Xcode Documentation) Instruments New Features User Guide Apple Developer Forums http://devforums.apple.com
Related Sessions iOS App Performance: Responsiveness Presidio Thursday 11:30AM iOS
App Performance: Graphics and Animations Presidio Thursday 3:15PM iOS App Performance: Memory Presidio Thursday 4:30PM
Labs Xcode Lab Developer Tools Lab B Ongoing
None
None
None
None