フォアグラウンド サービスのドキュメントでは、Android フォアグラウンド サービスの現在の動作について説明します。このドキュメントでは、Android の最新バージョンをターゲットにしているかどうかに関係なく、ほとんどのアプリに適用できるベスト プラクティスについて説明します。
このページでは、フォアグラウンド サービスに対する最近の重要な変更と、Android プラットフォームの最新バージョンをターゲットにしていないアプリへの影響について説明します。多くの場合、低い API レベルをターゲットとするアプリでは任意だったベスト プラクティスが、高い API レベルをターゲットとするアプリでは必須になります。
Android 16(API レベル 36)
API レベルに関係なく、Android 16 以降で実行されるアプリには、次の変更が適用されます。
フォアグラウンド サービスから開始されたバックグラウンド ジョブは、それぞれのランタイム割り当てに準拠する必要があります。これには、
JobSchedulerで直接スケジュールされたジョブと、 WorkManagerやDownloadManagerなどの他のライブラリによって作成されたジョブが含まれます。ユーザー操作に応じてデータを転送するには、 ユーザーが開始するデータ転送ジョブの使用を検討してください。これらのジョブは、通常のジョブ割り当ての対象外です。
Android 15(API レベル 35)
API レベル 35 以降をターゲットとするアプリには、次の要件が適用されます。
dataSyncフォアグラウンド サービスの実行時間に関する新しい制限があります。これらの制限については、フォアグラウンド サービスのタイムアウト 動作をご覧ください。同様の制限が、Android 15 で新しく導入されたmediaProcessingフォアグラウンド サービス タイプにも適用されます。BOOT_COMPLETEDフォアグラウンド サービスは、特定の フォアグラウンド サービスを起動できなくなりました。SYSTEM_ALERT_WINDOW権限を持つアプリは、現在表示されている オーバーレイ ウィンドウがある場合(またはバックグラウンドからの起動制限の他の 例外のいずれかに該当する場合)にのみ、バックグラウンドから フォアグラウンド サービスを起動できます。以前は、これらのアプリの例外はより広範でした。
Android 14(API レベル 34)
API レベル 34 以降をターゲットとするアプリには、次の要件が適用されます。
- すべてのフォアグラウンド サービスをサービス タイプとともに申告する必要があります。
- アプリは、フォアグラウンド サービスが行う作業の種類に適した権限タイプをリクエストする必要があります。フォアグラウンド サービス タイプごとに、対応する権限タイプがあります。たとえば、カメラを使用する
フォアグラウンド サービスをアプリが起動する場合は、
FOREGROUND_SERVICE権限とFOREGROUND_SERVICE_CAMERA権限の両方をリクエストする必要があります。API レベル 34 以降をターゲットとするアプリが、適切な特定の権限をリクエストしない場合、システムはSecurityExceptionをスローします。
Android 12(API レベル 31)
API レベル 31 以降をターゲットとするアプリには、次の要件が適用されます。
- アプリがバックグラウンドにある場合、アプリはフォアグラウンド サービスを起動できません。ただし、いくつかの例外があります。詳細と、 このルールの例外については、バックグラウンドからのフォアグラウンド サービスの起動に関する制限をご覧ください。
Android 11(API レベル 30)
API レベル 30 以降をターゲットとするアプリには、次の要件が適用されます。
- アプリのフォアグラウンド サービスがカメラまたはマイクを使用する場合、アプリはそれぞれ
cameraまたはmicrophoneサービス タイプでサービスを 宣言する必要があります。
Android 10(API レベル 29)
API レベル 29 以降をターゲットとするアプリには、次の要件が適用されます。
Android 9(API レベル 28)
Android 9 では、
FOREGROUND_SERVICE 権限が導入されました。Android 9 で実行され、フォアグラウンド サービスを使用するアプリには、この権限が必要です。
API レベル 28 以降をターゲットとするアプリが、
権限をリクエストせずにフォアグラウンド サービスを作成しようとすると、システムは FOREGROUND_SERVICE
SecurityExceptionをスローします。