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.Logoff и 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 не вызывается элементом консольных приложений.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).

Применяется к

Дополнительно