Click here to Skip to main content
13,356,787 members (58,204 online)
Click here to Skip to main content
Add your own
alternative version


61 bookmarked
Posted 27 Jan 2008

Make Your Application Shutdown Aware

, 27 Jan 2008
Rate this:
Please Sign up or sign in to vote.
This article explains how to make your application shutdown aware




This article is not an out of the box article. However I feel this may bring in some more ideas in the field of application development because knowledge makes you think beyond limitation.


I was working with one application and my client wanted the application to be system shutdown aware. I remembered that lot many applications do some task based on closing of an application but rarely saw any application which differentiated user shutdown and system shutdown. I thought why not make people aware that there is something which may change in the application design.

I have seen a couple of applications which handle FormClosing event and show MessageBox of closing, but when system shutdown is requested, they still show the message and end up with either data loss or prevent system shutdown.

So I decided to put this in the form of an article.

Basic Idea

FormClosingEventArgs is derived from CancelEventArgs. FormClosingEventArgs has a property (CloseReason) which tells you the reason for closing. This may be used in identifying and handling the close reason.

Now you have two options to get this arguments during close.

  1. You can override OnClosing method declared in Form and cast CancelEventArgs e to FormClosingEventArgs:

    protected override void OnClosing(CancelEventArgs e) 
        //Your alternate implementation
        FormClosingEventArgs ce = e as FormClosingEventArgs; 
        if (ce != null) 
            //Handle ce
  2. You can use event FormClosing:

    private void SampleForm_FormClosing(object sender, FormClosingEventArgs e)
        //Your alternate implementation

Handle Close Scenario

switch (ce.CloseReason)
    case CloseReason.ApplicationExitCall:
        //Handle application exit call
    case CloseReason.FormOwnerClosing:
        //Handle Form owner close
    case CloseReason.MdiFormClosing:
        //Handle MDI parent closing
    case CloseReason.None:
        //Handle unknown reason
    case CloseReason.TaskManagerClosing:
        //Handle taskmanager close
    case CloseReason.UserClosing:
        Handle User close
    case CloseReason.WindowsShutDown:
        //Handle system shutdown

Points of Interest

If you go through the MSDN documentation, you will find the following details of CloseReason. The names itself are self explanatory:

  • ApplicationExitCall - The Exit method of the application class was invoked.
  • FormOwnerClosing - The owner form is closing.
  • MdiFormClosing - The parent form of this multiple document interface (MDI) form is closing.
  • None - The cause of the closure was not defined or could not be determined.
  • TaskManagerClosing - The Microsoft Windows Task Manager is closing the application.
    UserClosing - The user is closing the form through the user interface (UI), for example by clicking the Close button on the form window, selecting Close from the Window's control menu, or pressing ALT+F4.
  • WindowsShutDown - The operating system is closing all applications before shutting down.


  • 28th January, 2008: Initial post


This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


About the Author

Manish Ranjan Kumar
Software Developer (Senior)
India India
No Biography provided

You may also be interested in...


Comments and Discussions

Generalsome issue Pin
arif.setiawan24-Feb-10 15:10
memberarif.setiawan24-Feb-10 15:10 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

Permalink | Advertise | Privacy | Terms of Use | Mobile
Web01 | 2.8.180111.1 | Last Updated 28 Jan 2008
Article Copyright 2008 by Manish Ranjan Kumar
Everything else Copyright © CodeProject, 1999-2018
Layout: fixed | fluid