Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Android: Track number of objects created

I'm porting a game to Android (there's a lot of code and very little of it is mine), and DalvikVM is telling me (through LogCat) all about the garbage collection. At some point in the code, I get a stream of "GC freed x objects / x ms" messages, basically informing me that ~150,000 objects have just been deleted and it's taking a full second.

I want to know where these came from! I am pretty sure I'm not creating that many objects intentionally.

So, is there a way to get... basically the opposite of that message? Something that prints a log message when any object is created?

That way I could step over the code, checking how many messages are generated, and seeing which parts of code are generating the objects. I suspect some form of object creation in part of a loop, but if possible this would be an easy way to tell for sure.

I'm using Eclipse 3.4.2, if that's relevant.

Any ideas?

like image 411
mcccclean Avatar asked May 01 '09 00:05

mcccclean


1 Answers

This is possible using the ddms tool that comes with Android (not the Eclipse version). Using that, look at the allocation tracker tab. You can start tracking allocations of all objects along with stack traces of where they were allocated. However, this tool can produce a -lot- of information and the particular information you want is not always easy to parse or find. If you have a version for the Sun JVM, I would recommend using the tools Kai mentioned, they are a lot more developed. If you have to do it in Android, using the allocation tracker will give you a start.

like image 192
sooniln Avatar answered Sep 27 '22 18:09

sooniln