Support your app with background tasks
The topics in this section show you how to make lightweight code run in the background in response to triggers. You can use background tasks to provide functionality when your app is suspended or not running. You can also use background tasks for real-time communication apps like VOIP, mail, and IM.
Playing media in the background
Starting in Windows 10, version 1607, playing audio in the background is much easier. See Play media in the background for more information.
In-process and out-of-process background tasks
There are two approaches to implementing background tasks:
- In-process: the app and its background process run in the same process
- Out-of-process: the app and the background process run in separate processes.
In-process background support was introduced in Windows 10, version 1607, to simplify writing background tasks. But you can still write out-of-process background tasks. See Guidelines for background tasks for recommendations on when to write an in-process versus out-of-process background task.
Out-of-process background tasks are more resilient because the background process can't bring down your app process if something goes wrong. But the resiliency comes at the price of greater complexity to manage the cross-process communication between the app and the background task.
Out-of-process background tasks are implemented as lightweight classes that implement the IBackgroundTask interface that the OS runs in a separate process (backgroundtaskhost.exe). Register a background task by using the BackgroundTaskBuilder class. The class name is used to specify the entry point when you registering the background task.
In Windows 10, version 1607, you can enable background activity without creating a background task. You can instead run your background code directly inside the foreground application's process.
To get started quickly with in-process background tasks, see Create and register an in-process background task.
To get started quickly with out-of-process background tasks, see Create and register an out-of-process background task.
Starting with Windows 10, you no longer need to place an app on the lock screen as a prerequisite for registering a background task for it.
Background tasks for system events
|InternetAvailable||The Internet becomes available.|
|NetworkStateChange||A network change such as a change in cost or connectivity occurs.|
|OnlineIdConnectedStateChange||Online ID associated with the account changes.|
|SmsReceived||A new SMS message is received by an installed mobile broadband device.|
|TimeZoneChange||The time zone changes on the device (for example, when the system adjusts the clock for daylight saving time).|
For more info see Respond to system events with background tasks.
Conditions for background tasks
You can control when the background task runs, even after it is triggered, by adding a condition. Once triggered, a background task will not run until all of its conditions are met. The following conditions (represented by the SystemConditionType enumeration) can be used.
|InternetAvailable||The Internet must be available.|
|InternetNotAvailable||The Internet must be unavailable.|
|SessionConnected||The session must be connected.|
|SessionDisconnected||The session must be disconnected.|
|UserNotPresent||The user must be away.|
|UserPresent||The user must be present.|
Add the InternetAvailable condition to your background task BackgroundTaskBuilder.AddCondition to delay triggering the background task until the network stack is running. This condition saves power because the background task won't execute until the network is available. This condition does not provide real-time activation.
If your background task requires network connectivity, set IsNetworkRequested to ensure that the network stays up while the background task runs. This tells the background task infrastructure to keep the network up while the task is executing, even if the device has entered Connected Standby mode. If your background task does not set IsNetworkRequested, then your background task will not be able to access the network when in Connected Standby mode (for example, when a phone's screen is turned off.) For more info about background task conditions, see Set conditions for running a background task.
Application manifest requirements
Before your app can successfully register a background task that runs out-of-process, it must be declared in the application manifest. Background tasks that run in the same process as their host app do not need to be declared in the application manifest. For more info see Declare background tasks in the application manifest.
The following real-time triggers can be used to run lightweight custom code in the background:
|Control Channel||Background tasks can keep a connection alive, and receive messages on the control channel, by using the ControlChannelTrigger. If your app is listening to a socket, you can use the Socket Broker instead of the ControlChannelTrigger. For more details on using the Socket Broker, see SocketActivityTrigger. The ControlChannelTrigger is not supported on Windows Phone.|
|Timer||Background tasks can run as frequently as every 15 minutes, and they can be set to run at a certain time by using the TimeTrigger. For more info see Run a background task on a timer.|
|Push Notification||Background tasks respond to the PushNotificationTrigger to receive raw push notifications.|
Universal Windows apps must call RequestAccessAsync before registering any of the background trigger types.
To ensure that your Universal Windows app continues to run properly after you release an update, call RemoveAccess and then call RequestAccessAsync when your app launches after being updated. For more information, see Guidelines for background tasks.
Limits on the number of trigger instances: There are limits to how many instances of some triggers an app can register. An app can only register ApplicationTrigger, MediaProcessingTrigger and DeviceUseTrigger once per instance of the app. If an app goes over this limit, registration will throw an exception.
System event triggers
The SystemTriggerType enumeration represents the following system event triggers:
|UserPresent||The background task is triggered when the user becomes present.|
|UserAway||The background task is triggered when the user becomes absent.|
|ControlChannelReset||The background task is triggered when a control channel is reset.|
|SessionConnected||The background task is triggered when the session is connected.|
The following system event triggers signal when the user has moved an app on or off the lock screen.
|LockScreenApplicationAdded||An app tile is added to the lock screen.|
|LockScreenApplicationRemoved||An app tile is removed from the lock screen.|
Background task resource constraints
Background tasks are lightweight. Keeping background execution to a minimum ensures the best user experience with foreground apps and battery life. This is enforced by applying resource constraints to background tasks.
Background tasks are limited to 30 seconds of wall-clock usage.
Due to the resource constraints for low-memory devices, background tasks may have a memory limit that determines the maximum amount of memory the background task can use. If your background task attempts an operation that would exceed this limit, the operation will fail and may generate an out-of-memory exception--which the task can handle. If the task does not handle the out-of-memory exception, or the nature of the attempted operation is such that an out-of-memory exception was not generated, then the task will be terminated immediately.
You can use the MemoryManager APIs to query your current memory usage and limit in order to discover your cap (if any), and to monitor your background task's ongoing memory usage.
Per-device limit for apps with background tasks for low-memory devices
On memory-constrained devices, there is a limit to the number of apps that can be installed on a device and use background tasks at any given time. If this number is exceeded, the call to RequestAccessAsync, which is required to register all background tasks, will fail.
Unless you exempt your app so that it can still run background tasks and receive push notifications when Battery Saver is on, the Battery Saver feature, when enabled, will prevent background tasks from running when the device is not connected to external power and the battery goes below a specified amount of power remaining. This will not prevent you from registering background tasks.
However, for enterprise apps, and apps that will not be published in the Microsoft Store, see Run in the background indefinitely to learn how to use a capabilities to run a background task or extended execution session in the background indefinitely.
Background task resource guarantees for real-time communication
To prevent resource quotas from interfering with real-time communication functionality, background tasks using the ControlChannelTrigger and PushNotificationTrigger receive guaranteed CPU resource quotas for every running task. The resource quotas are as mentioned above, and remain constant for these background tasks.
Your app doesn't have to do anything differently to get the guaranteed resource quotas for ControlChannelTrigger and PushNotificationTrigger background tasks. The system always treats these as critical background tasks.
Maintenance tasks only run when the device is plugged in to AC power. For more info see Use a maintenance trigger.
Background tasks for sensors and devices
Your app can access sensors and peripheral devices from a background task with the DeviceUseTrigger class. You can use this trigger for long-running operations such as data synchronization or monitoring. Unlike tasks for system events, a DeviceUseTrigger task can only be triggered while your app is running in the foreground and no conditions can be set on it.
The DeviceUseTrigger and DeviceServicingTrigger cannot be used with in-process background tasks.
Some critical device operations, such as long running firmware updates, cannot be performed with the DeviceUseTrigger. Such operations can be performed only on the PC, and only by a privileged app that uses the DeviceServicingTrigger. A privileged app is an app that the device's manufacturer has authorized to perform those operations. Device metadata is used to specify which app, if any, has been designated as the privileged app for a device. For more info, see Device sync and update for Microsoft Store device apps
Managing background tasks
Background tasks can report progress, completion, and cancellation to your app using events and local storage. Your app can also catch exceptions thrown by a background task, and manage background task registration during app updates. For more info see:
Check your background task registration during app launch. Ensure that your app's ungrouped background tasks are present in BackgroundTaskBuilder.AllTasks. Re-register the ones that are not present. Unregister any tasks that are no longer needed. This ensures that all background tasks registrations are up-to-date every time the app is launched.
Conceptual guidance for multitasking in Windows 10
Related background task guidance
- Guidelines for background tasks
- Access sensors and devices from a background task
- Create and register an in-process background task
- Create and register an out-of-process background task
- Convert an out-of-process background task to an in-process background task
- Debug a background task
- Declare background tasks in the application manifest
- Group background task registration
- Handle a cancelled background task
- How to trigger suspend, resume, and background events in UWP apps (when debugging)
- Monitor background task progress and completion
- Play media in the background
- Register a background task
- Respond to system events with background tasks
- Run a background task on a timer
- Run a background task when your UWP app is updated
- Run in the background indefinitely
- Set conditions for running a background task
- Trigger a background task from your app
- Update a live tile from a background task
- Use a maintenance trigger
Submit and view feedback for