- Unity 2017 Game Optimization(Second Edition)
- Chris Dickinson
- 471字
- 2021-07-02 23:21:04
Best approaches to performance analysis
Good coding practices and project asset management often make finding the root cause of a performance issue relatively simple, at which point the only real problem is figuring out how to improve the code. For instance, if the method only processes a single gigantic for loop, then it will be a pretty safe assumption that the problem is either with how many iterations the loop is performing, whether or not the loop is causing cache misses by reading memory in a non-sequential fashion, how much work is done in each iteration, or how much work it takes to prepare for the next iteration.
Of course, whether we're working inpidually or in a group setting, a lot of our code is not always written in the cleanest way possible, and we should expect to have to profile some poor coding work from time to time. Sometimes we are forced to implement a hacky solution for the sake of speed, and we don't always have the time to go back and refactor everything to keep up with our best coding practices. In fact, many code changes made in the name of performance optimization tend to appear very strange or arcane, often making our codebase more difficult to read. The common goal of software development is to make code that is clean, feature-rich, and fast. Achieving one of these is relatively easy, but the reality is that achieving two will cost significantly more time and effort, while achieving all three is a near-impossibility.
At its most basic level, performance optimization is just another form of problem-solving, and overlooking the obvious while problem-solving can be an expensive mistake. Our goal is to use benchmarking to observe our application looking for instances of problematic behavior, then use instrumentation to hunt through the code for clues about where the problem originates. Unfortunately, it's often very easy to get distracted by invalid data or jump to conclusions because we're being too impatient or missed a subtle detail. Many of us have run into occasions during software debugging where we could have found the root cause of the problem much faster if we had simply challenged and verified our earlier assumptions. Hunting down performance issues is no different.
A checklist of tasks would be helpful to keep us focused on the issue, and not waste time chasing so-called ghosts. Of course, every project is different, with its own unique challenges to overcome, but the following checklist is general enough that it should be able to apply to any Unity project:
- Verifying that the target script is present in the Scene
- Verifying that the script appears in the Scene the correct number of times
- Verifying the correct order of events
- Minimizing ongoing code changes
- Minimizing internal distractions
- Minimizing external distractions
- Learning Apex Programming
- FFmpeg入門詳解:音視頻流媒體播放器原理及應(yīng)用
- Java Web及其框架技術(shù)
- HTML5 and CSS3 Transition,Transformation,and Animation
- Mastering KnockoutJS
- SharePoint Development with the SharePoint Framework
- Cocos2d-x學(xué)習(xí)筆記:完全掌握Lua API與游戲項(xiàng)目開發(fā) (未來書庫)
- 零基礎(chǔ)學(xué)單片機(jī)C語言程序設(shè)計(jì)
- Beginning C# 7 Hands-On:The Core Language
- Building UIs with Wijmo
- Pandas 1.x Cookbook
- Elastix Unified Communications Server Cookbook
- MySQL核心技術(shù)與最佳實(shí)踐
- GO語言編程從入門到實(shí)踐
- Python快速編程入門