官术网_书友最值得收藏!

Profiler script control

The Profiler can be controlled in script code through the Profiler class. There are several useful methods in this class that we can explore within the Unity documentation, but the most important methods are the delimiter methods that activate and deactivate profiling at runtime. These can be accessed through the UnityEngine.Profiling.Profiler class through its BeginSample() and EndSample() methods.

Note that the delimiter methods, BeginSample() and EndSample(), are only compiled in development builds, and as such, they will not be compiled or executed in release builds where Development Mode is unchecked. This is commonly known as non-operation or no-op code.

The BeginSample() method has an overload that allows a custom name for the sample to appear in the CPU Usage Area's Hierarchy mode. For example, the following code will profile invocations of this method and make the data appear in the Breakdown View under a custom heading, as follows:

void DoSomethingCompletelyStupid() { 
Profiler.BeginSample("My Profiler Sample");
List<int> listOfInts = new List<int>();
for(int i = 0; i < 1000000; ++i) {
listOfInts.Add(i);
}
Profiler.EndSample();
}

You can download the example code files from your account at http://www.packtpub.com for all the Packt Publishing books you have purchased. If you purchased this book elsewhere, you can visit http://www.packtpub.com/support and register to have the files emailed directly to you.

We should expect that invoking this poorly designed method (which generates a List containing a million integers, and then does absolutely nothing with it) will cause a huge spike in CPU usage, chew up several megabytes of memory, and appear in the Profiler Breakdown View under the heading My Profiler Sample, as the following screenshot shows:

主站蜘蛛池模板: 黄冈市| 绍兴市| 迁西县| 临江市| 泽州县| 静安区| 太原市| 丹寨县| 简阳市| 来宾市| 盐亭县| 西乌珠穆沁旗| 玉门市| 陕西省| 南部县| 确山县| 永年县| 永顺县| 诸暨市| 静宁县| 信丰县| 泽库县| 噶尔县| 包头市| 西畴县| 阿克苏市| 安阳市| 台北县| 临安市| 邵阳县| 聂荣县| 乌海市| 黄浦区| 闽侯县| 观塘区| 五寨县| 奉贤区| 丽江市| 万源市| 甘泉县| 镇原县|