Android 14 プラットフォームには、アプリに影響する可能性がある動作変更が含まれています。下記の動作変更は、targetSdkVersion
に関係なく、Android 14 上で稼働するすべてのアプリに適用されます。該当する場合は、アプリをテストし、必要に応じて修正して、適切に対応してください。
Android 14 をターゲットとするアプリにのみ影響する動作変更のリストも必ずご確認ください。
コア機能
正確なアラームのスケジュールはデフォルトで拒否される
精确的闹钟适用于用户指定的通知,或是在确切时间需要执行的操作。从 Android 14 开始,系统不再向以 Android 13 及更高版本为目标平台的大多数新安装应用预先授予 SCHEDULE_EXACT_ALARM
权限,该权限默认处于拒绝状态。
详细了解安排精确闹钟的权限变化。
アプリがキャッシュされている間、コンテキスト登録されたブロードキャストがキューに追加される
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 蓝牙堆栈会更严格地遵循 蓝牙核心规范 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 增加了系统显示您在 Play 管理中心表单中声明的信息的位置数量。目前,用户可以在 Google Play 中的应用详情的数据安全部分查看此信息。
我们建议您查看应用的位置数据分享政策,并花一点时间对应用的 Google Play“数据安全”部分进行任何适用的更新。
如需了解详情,请参阅有关如何在 Android 14 上以更显眼的方式显示数据安全信息的指南。
ユーザー補助
非線形フォント スケーリングを 200% にする
从 Android 14 开始,系统支持字体放大高达 200%,为弱视用户提供了符合网络内容无障碍指南 (WCAG) 的其他无障碍功能选项。
如果您已使用放大像素 (sp) 单位来定义文本大小,这项更改可能不会对您的应用产生太大影响。不过,您应在启用最大字号 (200%) 的情况下执行界面测试,确保应用能够在不影响易用性的情况下适应较大的字号。
セキュリティ
インストール可能な最小対象 API レベル
Android 14 以降では、targetSdkVersion
が 23 未満のアプリはインストールできません。これらの最小対象 API レベルの要件をアプリが満たすことを必須とすることで、ユーザーのセキュリティとプライバシーを強化しています。
マルウェアは多くの場合、新しい Android バージョンで導入されたセキュリティとプライバシー保護を回避するため、古い API レベルをターゲットにします。たとえば、一部のマルウェア アプリは、2015 年に Android 6.0 Marshmallow(API レベル 23)で導入された実行時の権限モデルの対象にならないよう、22 の targetSdkVersion
を使用します。この 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 开始,除非满足以下条件之一,否则系统会隐去此值:
- 存储媒体文件的应用有一个软件包名称始终对其他应用可见。
查询媒体库的应用会请求
QUERY_ALL_PACKAGES
权限。
详细了解 Android 如何出于隐私保护目的而过滤软件包可见性。