Application.SessionEnding Application.SessionEnding Application.SessionEnding Application.SessionEnding Event

定義

ユーザーがログオフするかオペレーティング システムをシャットダウンして、Windows セッションを終了するときに発生します。Occurs when the user ends the Windows session by logging off or shutting down the operating system.

public:
 event System::Windows::SessionEndingCancelEventHandler ^ SessionEnding;
public event System.Windows.SessionEndingCancelEventHandler SessionEnding;
member this.SessionEnding : System.Windows.SessionEndingCancelEventHandler 
Public Custom Event SessionEnding As SessionEndingCancelEventHandler 

次の例は、処理する方法を示します、SessionEndingイベントと、ユーザーがキャンセルできるようにします。The following example demonstrates how to handle the SessionEnding event and allow the user to cancel it.

<Application 
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    x:Class="SDKSample.App"
    StartupUri="MainWindow.xaml"
    SessionEnding="App_SessionEnding" />
using System.Windows;

namespace SDKSample
{
    public partial class App : Application
    {
        void App_SessionEnding(object sender, SessionEndingCancelEventArgs e)
        {
            // Ask the user if they want to allow the session to end
            string msg = string.Format("{0}. End session?", e.ReasonSessionEnding);
            MessageBoxResult result = MessageBox.Show(msg, "Session Ending", MessageBoxButton.YesNo);

            // End session, if specified
            if (result == MessageBoxResult.No)
            {
                e.Cancel = true;
            }
        }
    }
}

Imports Microsoft.VisualBasic
Imports System.Windows

Namespace SDKSample
	Partial Public Class App
		Inherits Application
		Private Sub App_SessionEnding(ByVal sender As Object, ByVal e As SessionEndingCancelEventArgs)
			' Ask the user if they want to allow the session to end
			Dim msg As String = String.Format("{0}. End session?", e.ReasonSessionEnding)
			Dim result As MessageBoxResult = MessageBox.Show(msg, "Session Ending", MessageBoxButton.YesNo)

			' End session, if specified
			If result = MessageBoxResult.No Then
				e.Cancel = True
			End If
		End Sub
	End Class
End Namespace

注釈

既定では、アプリケーションをシャット ダウンときに、ユーザーがログオフまたはシャット ダウン時に発生する Windows セッションが終了します。By default, an application shuts down when the Windows session ends, which occurs when a user logs off or shuts down. この場合、Windows は、各アプリケーションをシャット ダウンを要求します。When this happens, Windows asks each open application to shut down. ただしは、アプリケーションがシャット ダウンこのエラーが発生する準備ができていない可能性があります。However, it is possible that an application may not be ready to shut down when this occurs. たとえば、アプリケーションは、不整合な状態で、または実行時間の長い操作の途中でデータを場合があります。For example, an application may have data that is in an inconsistent state, or in the middle of a long-running operation. このような状況では、終了、セッションを防止することが望ましい場合があり、ユーザー セッションを終了できるようにするかどうかを決定するオプションを使用するが望ましい場合があります。In these situations, it may be desirable to prevent the session from ending, and may be more desirable to allow users the option to decide whether or not to let the session to end.

処理することにより、セッションの終了時に検出することができます、SessionEndingイベント。You can detect when a session ends by handling the SessionEnding event. 終了、セッションを防ぐためにアプリケーションに必要な場合、SessionEndingCancelEventArgsイベント ハンドラーに渡される引数を公開、Cancelに設定するtrue(既定値はfalse)。If an application needs to prevent the session from ending, the SessionEndingCancelEventArgs argument that is passed to the event handler exposes the Cancel that you set to true (the default value is false).

場合SessionEnding、処理がないか、取り消されてなしで処理されるShutdownが呼び出されます、Exitイベントが発生します。If SessionEnding is unhandled, or is handled without being cancelled, Shutdown is called and the Exit event is raised.

セッションが終了する理由の詳細を取得するアプリケーションを検査できますReasonSessionEndingのいずれかである、ReasonSessionEnding値 (ReasonSessionEnding.LogoffReasonSessionEnding.Shutdown)。To obtain more information about why the session is ending, an application can inspect ReasonSessionEnding, which is one of the ReasonSessionEnding values (ReasonSessionEnding.Logoff and ReasonSessionEnding.Shutdown).

SessionEnding コンソール アプリケーションでは発生しません。SessionEnding is not raised by console applications.

SessionEnding 作成したスレッドでのみ発生しますが、Applicationオブジェクト。SessionEnding is raised only on the thread that creates the Application object.

SessionEnding XAML ブラウザー アプリケーション (Xbap) は発生しません。SessionEnding is not raised for XAML browser applications (XBAPs).

適用対象

こちらもご覧ください