Application.SessionEnding Evento

Definizione

Si verifica quando l'utente termina la sessione di Windows mediante disconnessione o arresto del sistema operativo.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 

Esempi

Nell'esempio seguente viene illustrato come gestire l'evento SessionEnding e consentire all'utente di annullarlo.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 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

Commenti

Per impostazione predefinita, un'applicazione viene chiusa al termine della sessione di Windows, che si verifica quando un utente si disconnette o si arresta.By default, an application shuts down when the Windows session ends, which occurs when a user logs off or shuts down. Quando si verifica questa situazione, Windows chiede a ogni applicazione aperta di arrestarsi.When this happens, Windows asks each open application to shut down. Tuttavia, è possibile che un'applicazione non sia pronta per essere arrestata in questo caso.However, it is possible that an application may not be ready to shut down when this occurs. Ad esempio, un'applicazione può avere dati in uno stato incoerente o durante un'operazione a esecuzione prolungata.For example, an application may have data that is in an inconsistent state, or in the middle of a long-running operation. In questi casi potrebbe essere preferibile evitare che la sessione venga terminata e potrebbe essere più utile consentire agli utenti di decidere se consentire o meno la chiusura della sessione.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.

È possibile rilevare quando una sessione termina gestendo l'evento SessionEnding.You can detect when a session ends by handling the SessionEnding event. Se un'applicazione deve impedire che la sessione venga terminata, l'argomento SessionEndingCancelEventArgs passato al gestore eventi espone le Cancel impostate su true (il valore predefinito è 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).

Se SessionEnding non è gestita o viene gestita senza essere annullata, viene chiamato Shutdown e viene generato l'evento Exit.If SessionEnding is unhandled, or is handled without being cancelled, Shutdown is called and the Exit event is raised.

Per ottenere altre informazioni sui motivi della chiusura della sessione, un'applicazione può ispezionare ReasonSessionEnding, ovvero uno dei valori ReasonSessionEnding (ReasonSessionEnding.Logoff e ReasonSessionEnding.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 non viene generato dalle applicazioni console.SessionEnding is not raised by console applications.

SessionEnding viene generato solo sul thread che crea l'oggetto Application.SessionEnding is raised only on the thread that creates the Application object.

SessionEnding non viene generato per le applicazioni browser XAML (XBAPs).SessionEnding is not raised for XAML browser applications (XBAPs).

Si applica a

Vedi anche