Android 14 プラットフォームには、アプリに影響する可能性がある動作変更が含まれています。下記の動作変更は、targetSdkVersion
に関係なく、Android 14 上で稼働するすべてのアプリに適用されます。該当する場合は、アプリをテストし、必要に応じて修正して、適切に対応してください。
Android 14 をターゲットとするアプリにのみ影響する動作変更のリストも必ずご確認ください。
コア機能
正確なアラームのスケジュールはデフォルトで拒否される
精确的闹钟适用于用户指定的通知,或是在确切时间需要执行的操作。从 Android 14 开始,系统不再向以 Android 13 及更高版本为目标平台的大多数新安装应用预先授予 SCHEDULE_EXACT_ALARM
权限,该权限默认处于拒绝状态。
详细了解安排精确闹钟的权限变化。
アプリがキャッシュされている間、コンテキスト登録されたブロードキャストがキューに追加される
在 Android 14 中,当应用处于缓存状态时,系统可以将上下文注册的广播放入队列中。这与 Android 12(API 级别 31)为异步 binder 事务引入的队列行为类似。在清单中声明的广播不会加入队列,并且应用会从缓存状态中移除以进行广播传递。
当应用离开缓存状态(例如返回前台)时,系统会传递所有已加入队列的广播。某些广播的多个实例 可能会合并为一个广播。取决于其他因素,如系统 运行状况,则可能会从缓存状态中移除应用,以及之前排队 广播。
アプリは自身のバックグラウンド プロセスのみを強制終了できる
Starting in Android 14, when your app calls killBackgroundProcesses()
,
the API can kill only the background processes of your own app.
If you pass in the package name of another app, this method has no effect on that app's background processes, and the following message appears in Logcat:
Invalid packageName: com.example.anotherapp
Your app shouldn't use the killBackgroundProcesses()
API or otherwise attempt
to influence the process lifecycle of other apps, even on older OS versions.
Android is designed to keep cached apps in the background and kill them
automatically when the system needs memory. If your app kills other apps
unnecessarily, it can reduce system performance and increase battery consumption
by requiring full restarts of those apps later, which takes significantly more
resources than resuming an existing cached app.
MTU をリクエストした最初の GATT クライアントに対して MTU が 517 に設定される
Android 14 以降、Android Bluetooth スタックは Bluetooth コア仕様のバージョン 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 级别要求有助于提高用户的安全性和隐私性。
恶意软件通常会以较旧的 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 开始,除非满足以下条件之一,否则系统会隐去此值:
- 存储媒体文件的应用有一个软件包名称始终对其他应用可见。
查询媒体库的应用会请求
QUERY_ALL_PACKAGES
权限。
详细了解 Android 如何出于隐私保护目的而过滤软件包可见性。