Unload event for the default Application Domain?
Asked Answered
S

2

4

Is there an Unload event, or any event, notification, message, mechanism, or hook, that i can use to be notified before the "default" application domain is unloaded?

i have code that needs to know when the application domain (almost always the default domain) is ending.

Note: i don't know what kind of application a developer will be creating when he uses my code. It could be:

  • a console application
  • a WinForms application
  • an ASP.net application
  • an ASP.net web-site
  • Runtime Callable Wrapper (RCW) COM object
  • a Windows Explorer shell extension
  • or a Windows Service

Either way, i need to know when the domain is closing, so i can do some "stuff". And i am not going to require the user to call any sort of "Shutdown" or "Cleanup" method. (Also, suggesting that the user be required to call a method themselves doesn't answer the question: which is about being notified when the app domain i'm running in is shut down).

See also

Stadium answered 3/8, 2013 at 12:56 Comment(8)
So you are building a library that would be consumed by other application and you want to know when the default app domain of those applications is unloaded ?Lenzi
Enumerating AppDomains is not possible.Telega
@Sniffer i want to know when the AppDomain that i am in (which 100% of the time will be the default domain) is being unloaded, so i can "shutdown".Stadium
You could put your cleanup logic in a critical finalizer object. That would be sort of an abuse though. Can't you go the other way around: don't cleanup on shutdown but on initializing? If you find there are left overs from a previous run, clean them up, if required. (i.e. "design for crash"). Leave the rest to the OS. Exiting the default-domain will exit the process anyway (not sure about hosted CLRs though).Gamages
@Gamages The issue with "cleanup" isn't to release resources. i need to perform tasks (e.g. flushing items to the filing system, saving statistics to SQL Server, uploading persistent state to a web-server). And i want to do it without the user having to call some sort of Shutdown() method (like i don't have to do in other languages).Stadium
OK, I understand. Have you looked at AppDomain.ProcessExit. Conceptually that event should also signal the end of the default-AppDomain (and is also raised in the default domain). The total execution time of suche event handlers is limited, however, and the work you try to do sounds rather "involved". YMMV.Gamages
#16673832 might provide some hintsDameron
It should be noted that AppDomain.ProcessExit won't fire if the process is terminated through, for example, the Task Manager.Michaelmas
S
8

i forgot to cross post my own answer from my other slight variation of this question. Ultimately, the answer came from an answer by M.A. Hanin.

There is no DomainUnload, but there is a ProcessExit:

class Contoso
{
   //constructor
   public Contoso()
   {
      //...

      //Catch domain shutdown (Hack: frantically look for things we can catch)
      if (AppDomain.CurrentDomain.IsDefaultAppDomain())
         AppDomain.CurrentDomain.ProcessExit += MyTerminationHandler;
      else
         AppDomain.CurrentDomain.DomainUnload += MyTerminationHandler;
   }

   private void MyTerminationHandler(object sender, EventArgs e)
   {
      //The domain is dying. Serialize out our values
      this.Dispose();
   }

   ...
}

Note: Any code is released into the public domain. No attribution required.

Stadium answered 6/9, 2013 at 18:20 Comment(1)
There is actually a DomainUnload event. Just wanted to clarify that, though the way that you did this is actually better.Horseleech
R
4
AppDomain.CurrentDomain.DomainUnload += 
    (object sender, EventArgs e) => { /*do stuff*/ };
Ruy answered 1/10, 2014 at 1:39 Comment(1)
This doesn't seem to be firing for the default domain.Brana

© 2022 - 2024 — McMap. All rights reserved.