I need help on stracing Android apps in the SDK emulator.
Here is my setup:
I have an Android SDK emulator running the Android API 4.03 ADB shell connected to emulator.
I am able to install an APK using the ADB install filename.apk
I am able to run the app using the ADB shell am start -a android.intent.action.Main -n com.akproduction.notepad/com.akproduction.notepad.NoteList
I try to strace using (ADB shell) strace am start -a android.intent.action.Main -n com.akproduction.notepad/com.akproduction.notepad.NoteList
but I get nothing!
How do you trace the runtime behavior of Android apps and their installation?
(P.S. The test app is located here.
The "am start" command does not directly run your application; it simply tells Android to do whatever is necessary to, in your example, start a specific activity.
The strace
command is normally used as in strace commandname command args
and it launches commandname
-- easy, but in this Android use case, not helpful. However, strace has a -p
option which is helpful to you: strace -p <process id>
will let you start tracing the process with the specified id.
If you type ps
on your Android system you can locate the process with the name com.akproduction.notepad
(probably; by default processes are named for their Android package, but it's possible to change that in the manifest). Then you can start stracing it, wherever it happens to be.
If you need to catch things early in the process, you'll need to either modify the code to cause it to delay until you're ready to trace it, or you'll at least need to get the process running before you start the activity. The second option there is often as easy as starting the activity, then using the back button, then getting your trace ready, then starting the activity again -- but this is always code-specific to the application.