動作の変更点: すべてのアプリ

Android 14 プラットフォームには、アプリに影響する可能性がある動作変更が含まれています。下記の動作変更は、targetSdkVersion に関係なく、Android 14 上で稼働するすべてのアプリに適用されます。該当する場合は、アプリをテストし、必要に応じて修正して、適切に対応してください。

Android 14 をターゲットとするアプリにのみ影響する動作変更のリストも必ずご確認ください。

コア機能

正確なアラームのスケジュールはデフォルトで拒否される

正確なアラームは、ユーザーの意図に基づく通知や、正確な時刻で実行する必要があるアクションに適しています。Android 14 以降では、SCHEDULE_EXACT_ALARM 権限が、Android 13 以降をターゲットとする新しくインストールされたアプリのほとんどで、事前付与されなくなりました。この権限はデフォルトで拒否されます。

詳しくは、正確なアラームのスケジュール設定の権限の変更をご覧ください。

アプリがキャッシュされている間、コンテキスト登録されたブロードキャストがキューに追加される

Android 14 では、アプリがキャッシュに保存された状態にあるときに、コンテキスト登録されたブロードキャストがキューに配置されることがあります。これは、Android 12(API レベル 31)で非同期バインダー トランザクションに導入されたキュー動作に似ています。マニフェストで宣言されたブロードキャストはキューに登録されず、アプリはブロードキャスト配信のためにキャッシュに保存された状態から削除されます。

アプリがフォアグラウンドに戻るなど、キャッシュに保存された状態を終了すると、キュー内のブロードキャストがすべて配信されます。特定のブロードキャストの複数のインスタンス 1 つのブロードキャストに統合される場合があります他の要因(システムなど)による アプリはキャッシュから削除されたり、以前にキューに入れられた ブロードキャストが配信されます。

アプリは自身のバックグラウンド プロセスのみを強制終了できる

Android 14 以降では、アプリが killBackgroundProcesses() を呼び出した場合、API は自身のアプリのバックグラウンド プロセスのみを強制終了できます。

別のアプリのパッケージ名を渡した場合、このメソッドはそのアプリのバックグラウンド プロセスに影響せず、Logcat に次のメッセージが表示されます。

Invalid packageName: com.example.anotherapp

古いバージョンの OS であっても、アプリで killBackgroundProcesses() API を使用したり、他のアプリプロセスのライフサイクルに影響を与えようとしたりしないでください。Android は、キャッシュに保存されたアプリをバックグラウンドで保持し、システムにメモリが必要なときは自動的にそうしたアプリを強制終了するように設計されています。アプリが不必要に他のアプリを強制終了した場合、後でそれらのアプリを完全に再起動する必要があるため、システム パフォーマンスが低下し、バッテリー消費量が増加する可能性があります。これには、キャッシュに保存された既存のアプリを再開するよりもはるかに多くのリソースが必要になります。

MTU をリクエストする最初の GATT クライアントの MTU が 517 に設定される

Android 14 以降、Android Bluetooth スタックは Bluetooth Core Specification バージョン 5.2 に厳密に準拠し、最初の GATT クライアントが BluetoothGatt#requestMtu(int) API を使用して MTU をリクエストすると、BLE ATT MTU を 517 バイトにリクエストし、その ACL 接続で後続の MTU リクエストをすべて無視します。

この変更に対応し、アプリの堅牢性を高めるには、次のオプションを検討してください。

  • 周辺機器デバイスは、Android デバイスの MTU リクエストに、周辺機器で対応できる妥当な値で応答する必要があります。最終的なネゴシエート値は、Android がリクエストした値とリモートで提供された値(min(517, remoteMtu) など)の最小値になります。
    • この修正を実装するには、周辺機器のファームウェアのアップデートが必要になる場合があります
  • または、ペリフェラルの既知のサポート対象値と受信した MTU 変更の最小値に基づいて、GATT 特性の書き込みを制限します。
    • ヘッダーのサポートされているサイズから 5 バイト減らす必要があることを示す注意事項
    • 例: arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5

アプリが制限付きスタンバイ バケットに配置される新しい理由

Android 14 では、アプリを制限付きスタンバイ バケットに配置できる新しい理由が導入されました。アプリのジョブで、onStartJobonStopJob、または onBind メソッドのタイムアウトが原因で ANR エラーが複数回トリガーされます。(onStartJobonStopJob の変更については、JobScheduler がコールバックとネットワークの動作を強化をご覧ください)。

アプリが制限付きスタンバイ バケットに入ったかどうかを追跡するには、ジョブの実行時に API UsageStatsManager.getAppStandbyBucket() を使用してロギングするか、アプリの起動時に UsageStatsManager.queryEventsForSelf() を使用してロギングすることをおすすめします。

mlock の上限は 64 KB

在 Android 14(API 级别 34)及更高版本中,平台将可使用 mlock() 锁定的最大内存量减少到每个进程 64 KB。在之前的版本中,每个进程的上限为 64 MB。此限制有助于更好地管理应用和系统的内存。为了在各种设备上提供更一致的体验,Android 14 针对兼容设备上的新 mlock() 限制添加了一项新的 CTS 测试

システムがキャッシュに保存されたアプリのリソース使用量を適用する

从设计上讲,当应用的进程移至后台且没有任何其他应用进程组件在运行时,应用进程将处于缓存状态。此类应用进程可能会因系统内存压力而终止。在此状态下,Activity 实例在调用并返回 onStop() 方法后执行的任何工作均不可靠,强烈建议不要这样做。

Android 14 对此设计引入了一致性和强制执行要求。在应用进程进入缓存状态后不久,系统会禁止后台工作,直到进程组件重新进入生命周期的活跃状态。

使用框架支持的典型生命周期 API(例如服务JobSchedulerJetpack WorkManager)的应用应该不受这些变化的影响。

ユーザー エクスペリエンス

閉じることができない通知のユーザー エクスペリエンスに関する変更

Android 14 では、アプリで閉じることができないフォアグラウンド通知をユーザーに表示する場合、ユーザーがそうした通知を閉じられるように動作が変更されました。

この変更は、ユーザーがフォアグラウンドを非表示にできないアプリに適用されます Notification.FLAG_ONGOING_EVENTNotification.Builder#setOngoing(true) または NotificationCompat.Builder#setOngoing(true)。これにより、FLAG_ONGOING_EVENT の動作が変更され、ユーザーがこのような通知を閉じられるようになりました。

次のような状況では引き続き、こうした通知を閉じることができません。

  • スマートフォンがロックされている場合
  • ユーザーが [すべて消去] 通知アクションを選択した場合(誤って消去しないようにするため)

また、この新しい動作は、 次のようなユースケースがあります。

  • CallStyle の通知
  • エンタープライズ向けの Device Policy Controller(DPC)とサポート パッケージ
  • メディアの通知
  • デフォルトの検索セレクタ パッケージ

データ セーフティ情報の視認性が向上

Android 14 では、ユーザーのプライバシーを保護するため、Google Play Console フォームで申告された情報を表示する場所を増やしています。現在のところ、この情報は、Google Play のアプリの掲載情報にあるデータ セーフティ セクションで確認できます。

アプリの位置情報の共有に関するポリシーを確認し、適宜 Google Play のデータ セーフティ セクションを更新することをおすすめします。

詳しくは、Android 14 でのデータ セーフティ情報の表示方法に関するガイドをご覧ください。

ユーザー補助

非線形フォント スケーリングを 200% にする

Android 14 以降では、フォント スケーリングが 200% までサポートされます。これにより、ユーザーは追加のユーザー補助オプションを利用できます。

スケール非依存ピクセル(sp)単位を使用してテキストサイズを定義している場合、この変更によるアプリへの影響はそれほどありません。ただし、最大フォントサイズ(200%)を有効にして UI テストを実施し、アプリがユーザビリティに影響を与えることなく大きなフォントサイズに対応できることを確認する必要があります。

セキュリティ

インストール可能な最小対象 API レベル

从 Android 14 开始,targetSdkVersion 低于 23 的应用无法安装。要求应用满足这些最低目标 API 级别要求有助于提高用户的安全性和隐私性。

恶意软件通常会以较旧的 API 级别为目标平台,以绕过在较新版本 Android 中引入的安全和隐私保护机制。例如,有些恶意软件应用使用 targetSdkVersion 22,以避免受到 Android 6.0 Marshmallow(API 级别 23)在 2015 年引入的运行时权限模型的约束。这项 Android 14 变更使恶意软件更难以规避安全和隐私权方面的改进限制。尝试安装以较低 API 级别为目标平台的应用将导致安装失败,并且 Logcat 中会显示以下消息:

INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 23, but found 7

在升级到 Android 14 的设备上,targetSdkVersion 低于 23 的所有应用都将继续保持安装状态。

如果您需要测试以旧版 API 级别为目标平台的应用,请使用以下 ADB 命令:

adb install --bypass-low-target-sdk-block FILENAME.apk

メディア所有者のパッケージ名が削除される場合がある

メディアストアは、OWNER_PACKAGE_NAME 列のクエリをサポートしています。この列は、特定のメディア ファイルを保存したアプリを示します。Android 14 以降では、次の条件の少なくとも 1 つに該当する場合を除き、この値が削除されます。

  • メディア ファイルを保存したアプリに、他のアプリに常に表示されるパッケージ名がある。
  • メディアストアをクエリするアプリが QUERY_ALL_PACKAGES 権限をリクエストする。

詳しくは、Android でプライバシー保護を目的としてパッケージの公開設定をフィルタする方法をご覧ください。