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 引入了一种可将应用放入受限待机模式存储分区的新原因。由于 onStartJob、onStopJob 或 onBind 方法超时,应用的作业多次触发 ANR 错误。(如需了解对 onStartJob 和 onStopJob 的更改,请参阅 JobScheduler 强化了回调和网络行为。)
如需跟踪应用是否已进入受限待机分桶,我们建议您在作业执行时使用 API UsageStatsManager.getAppStandbyBucket() 进行日志记录,或在应用启动时使用 UsageStatsManager.queryEventsForSelf() 进行日志记录。
mlock の上限は 64 KB
Android 14(API レベル 34)以降では、mlock() を使用してロックできる最大メモリがプロセスごとに 64 KB に減らされます。以前のバージョンでは、上限はプロセスごとに 64 MB でした。この制限により、アプリとシステム全体でメモリ管理が改善されます。デバイス間での整合性を高めるために、Android 14 では、互換性のあるデバイスの新しい mlock() の上限に関する新しい CTS テストが追加されています。
システムがキャッシュに保存されたアプリのリソース使用量を適用する
設計上、アプリのプロセスは、バックグラウンドに移行され、アプリの他のプロセス コンポーネントが実行されていない場合、キャッシュされた状態になります。このようなアプリのプロセスは、システムメモリの負荷が高くなったときに強制終了されます。アプリのプロセスがこのような状態にある場合、onStop() メソッドが呼び出され、返された後に Activity インスタンスが実行する処理の信頼性は低いため、このような状態で処理を実行しないことを強くおすすめします。
Android 14 では、この設計に一貫性と強制適用が導入されています。アプリのプロセスがキャッシュに保存された状態になった直後は、プロセス コンポーネントがライフサイクルのアクティブな状態に戻るまで、バックグラウンド処理が禁止されます。
各種サービス、JobScheduler、Jetpack WorkManager など、フレームワークでサポートされている一般的なライフサイクル API を使用するアプリは、この変更の影響を受けません。
ユーザー エクスペリエンス
閉じることができない通知のユーザー エクスペリエンスに関する変更
Android 14 では、アプリで閉じることができないフォアグラウンド通知をユーザーに表示する場合、ユーザーがそうした通知を閉じられるように動作が変更されました。
この変更は、ユーザーがフォアグラウンドを非表示にできないアプリに適用されます
Notification.FLAG_ONGOING_EVENT を
Notification.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 でプライバシー保護を目的としてパッケージの公開設定をフィルタする方法をご覧ください。