Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to find all instances of types that implement a given interface during debugging

I am looking for a way to locate all current instances on the heap of types that implement a given interface (during WinDbg debugging that is). As interfaces are not types in the sense that you can create instances of an interface, they obviously do not show up when inspecting the heap. I.e. !dumpheap is of little help here.

However, !dumpmt -md on a given MT lists the number of IFaces in IFaceMap. As far as I can tell this number seems to indicate if the type implements one or more interfaces or not. When using the -md flag methods on the type are also listed.

Unfortunately the !dumpmd doesn't tie a given method to an interface as far as I can tell, so this cannot be used to establish the implemented interfaces.

I assume this information is available somewhere in memory, but I am not sure where to look. Any input is highly appreciated.

like image 474
Brian Rasmussen Avatar asked Aug 20 '09 08:08

Brian Rasmussen


2 Answers

Have you tried

!dumpheap -type IFaces

It will show the method tables too. You can dig deeper from there.

like image 152
Dominic Zukiewicz Avatar answered Oct 21 '22 14:10

Dominic Zukiewicz


A few years ago, I was desperate for some information like this. I ended up creating a treeview that would only appear when you used an obscure option for starting the app. When I clicked "refresh", it would use reflection to travel through all the properties of the root class instance. If it found a property that was a collection or held other properties, it would recursively call into them. The end result was that a tree of the instance data at that point was available for perusal.

The main points to this approach are

  1. Make sure you have only one top-level object instance, or you know exactly how many and which top-level instances there are. (Also, don't forget about static values.)
  2. Figure out how to use reflection to look through the relevant bits of information.
  3. Display it when needed and in a readable fashion.
like image 32
John Fisher Avatar answered Oct 21 '22 15:10

John Fisher