I have a Java application that is leaking memory. I know which objects are not being freed during garbage collection, but I can\'t work out what is referencing them.
On a really basic level, you can use the commands jhat and jmap to read a heap file from a running Java process and then process it - it starts a small web server on a local port. It's not exactly easy to read, but you don't have to buy a profiler to use it.
Profilers do this. JProfiler for example. Back in the day I used Optimizeit (which seems to be dead now).
The conclusion was that listeners were being passed to some collection and not being removed from that collection. The listeners were anonymous inner classes defined on a Frame or a corresponding control class that referenced the Frame, and an anonymous inner class has an implicit reference to its outer class. So that little listener held the whole frame and all its attendant objects in active memory.