How to take heap snapshot of Xamarin.Android's Mono VM?

前端 未结 2 1514
忘了有多久
忘了有多久 2021-02-01 11:30

Background: I am trying to track down a memory leak in a Xamarin.Android app. Using DDMS and Eclipse Memory Profiler, I am able to see which objects are alive. When trying to tr

相关标签:
2条回答
  • 2021-02-01 11:34

    I have been having troubles with Xamarin Android memory profiling, and have used a few tricks:

    1. On the Dalvik side I have used Android Monitor to dump a heap snapshot and then opening it with JProfiler or Eclipse MAT. This standard Android.

    2. A large portion of my code is shared (70-80%) and to verify this I have built a simple WinForms application to drive the shared API. This way I can use .Net Memory Profiler (or ANTS if you would prefer) as well as dotTrace for performance. I could easily pick quite a few issues this way.

    3. By using the solution explained by @jnop above I could open the profile.mldp in Mono's HeapShot tool and get a visual tool instead of the mprof-report textual output.

    By the way used should vote for better profilers: http://xamarin.uservoice.com/forums/144858-xamarin-suggestions/suggestions/3229534-add-memory-and-performance-profiler

    0 讨论(0)
  • 2021-02-01 11:54

    How can I take a heap snapshot of the MONO VM? So I can later use it with i.e. heapshot tool?

    It is now possible to get heap snapshots of the Mono VM (tested with Xamarin.Android 4.8.2 beta; may apply to prior releases, your mileage may vary). It's a four step process:

    1. Enable heapshot logging:

      adb shell setprop debug.mono.profile log:heapshot
      
    2. Start your app. (If your app was already running before (1), kill and restart it.)

      Use your app.

    3. Grab the profile data for your app:

      adb pull /data/data/@PACKAGE_NAME@/files/.__override__/profile.mlpd
      

      @PACKAGE_NAME@ is the package name of your application, e.g. if your package is FooBar.FooBar-Signed.apk, then @PACKAGE_NAME@ will be FooBar.FooBar.

    4. Analyze the data:

      mprof-report profile.mlpd
      

      mprof-report is included with Mono.

    Note: profile.mlpd is only updated when a GC occurs, so you may want to call GC.Collect() at some "well known" point to ensure that profile.mlpd is regularly updated .

    0 讨论(0)
提交回复
热议问题