I'm reading this article here about running traceview on your android app: https://developer.android.com/studio/profile/traceview.html I assume the emulator they are talking about is the android emulator, not the Genymotion emulator which is the one I'm using.
It says to pull the trace file out of the emulator onto your host machine, you can just run the following commands:
adb pull /sdcard/startup.trace /tmp
I ran it on my Genymotion emulator and the file was not found. I then used the Android Device Monitor to look inside the device for the file but there was no file called startup.trace saved in that location.
I did this in my code:
public class MyApplication extends MultiDexApplication {
public void onCreate() {
super.onCreate();
Debug.startMethodTracing("startup");
}
}
Then I stoppedTracing in my activity onResume method to measure the startup time of my app:
@Override
protected void onResume() {
super.onResume();
Debug.stopMethodTracing();
}
I want the traceview to measure my startup time but don't know where the file is saved on my Genymotion emulator. Can anyone assist me with where the file is saved?
So after testing this with a simple android app, it actually works out as planned.
I have created a small repo to demonstrate this:
https://github.com/Winghin2517/TraceviewTest.git
You can download it, run it on your genymotion emulator and then type within the "Terminal" tab of Android Studios the following:
adb pull /sdcard/startup.trace /tmp
It will pull the trace file from Genymotion. Then you will need to switch on DDMS and say "File" -> "Open" and and open the startup.trace file.
The android app that I created demonstrate the time it takes to log out 1000 messages into the console. You can see the skin color bars represents the time android used to call my testCount
method:
Here are my results:
My method testCount took 10ms to complete.
The reclusive call to the Log.e
method also makes sense as my loop in my code is for 1000 calls to the log.e
method.
Incl CPU time is the inclusive cpu time. It is the sum of the time spent in the function itself, as well as the sum of the times of all functions that it calls.
Excl CPU time is the exclusive cpu time. It is only the time spent in the function itself. You'll notice that it is always the same as the "incl time" of the "self" child.