Thay đổi về hành vi: tất cả ứng dụng

Nền tảng Android 14 có các thay đổi về hành vi có thể ảnh hưởng đến ứng dụng của bạn. Những thay đổi về hành vi sau đây áp dụng cho tất cả ứng dụng khi chạy trên Android 14, bất kể targetSdkVersion. Bạn nên kiểm thử ứng dụng rồi sửa đổi để hỗ trợ những thay đổi này cho phù hợp (nếu cần).

Ngoài ra, hãy nhớ tham khảo danh sách thay đổi về hành vi chỉ ảnh hưởng đến những ứng dụng nhắm đến Android 14.

Chức năng cốt lõi

Theo mặc định, tính năng lên lịch chuông báo chính xác bị từ chối

Exact alarms are meant for user-intentioned notifications, or for actions that need to happen at a precise time. Starting in Android 14, the SCHEDULE_EXACT_ALARM permission is no longer being pre-granted to most newly installed apps targeting Android 13 and higher—the permission is denied by default.

Learn more about the changes to the permission for scheduling exact alarms.

Tin truyền đã đăng ký theo bối cảnh được đưa vào hàng đợi trong khi ứng dụng được lưu vào bộ nhớ đệm

Trên Android 14, hệ thống có thể đặt thông báo truyền tin đã đăng ký theo bối cảnh vào hàng đợi trong khi ứng dụng đang ở trạng thái được lưu vào bộ nhớ đệm. Điều này tương tự như hành vi xếp hàng mà Android 12 (API cấp 31) đã ra mắt cho các giao dịch liên kết không đồng bộ. Các tin truyền do tệp kê khai khai báo sẽ không được đưa vào hàng đợi và ứng dụng sẽ bị xoá khỏi trạng thái đã lưu vào bộ nhớ đệm để phân phối tin truyền.

Khi ứng dụng thoát khỏi trạng thái đã lưu vào bộ nhớ đệm (ví dụ: quay lại nền trước) hệ thống sẽ phân phối mọi tin truyền đã xếp hàng đợi. Có thể hợp nhất nhiều thực thể của một số tin truyền nhất định thành một tin truyền. Tuỳ thuộc vào các yếu tố khác, chẳng hạn như hệ thống sức khoẻ, ứng dụng có thể bị xoá khỏi trạng thái đã lưu vào bộ nhớ đệm và mọi trạng thái đã được đưa vào danh sách chờ trước đó tin nhắn truyền phát sẽ được phân phối.

Ứng dụng chỉ có thể loại bỏ các quy trình của riêng mình ở chế độ nền

Kể từ Android 14, khi ứng dụng của bạn gọi killBackgroundProcesses(), API này chỉ có thể loại bỏ các quy trình của ứng dụng đó ở chế độ nền.

Nếu bạn truyền tên gói của một ứng dụng khác vào, phương thức này sẽ không ảnh hưởng đến các quy trình trong nền của ứng dụng đó và thông báo sau sẽ xuất hiện trong Logcat:

Invalid packageName: com.example.anotherapp

Ứng dụng của bạn không nên sử dụng API killBackgroundProcesses(), hoặc tìm cách tác động đến vòng đời xử lý của các ứng dụng khác, ngay cả trên các phiên bản hệ điều hành cũ hơn. Android được thiết kế để tiếp tục lưu các ứng dụng vào bộ nhớ đệm trong nền, và tự động loại bỏ chúng khi hệ thống cần bộ nhớ. Nếu ứng dụng của bạn dừng các ứng dụng khác một cách không cần thiết, thì hiệu suất hệ thống có thể bị giảm và mức tiêu thụ pin sẽ tăng khi yêu cầu khởi động lại hoàn toàn các ứng dụng đó sau đó. Quá trình này sẽ tốn nhiều tài nguyên hơn đáng kể so với việc tiếp tục một ứng dụng hiện có đã lưu vào bộ nhớ đệm.

MTU được đặt thành 517 cho ứng dụng khách GATT đầu tiên yêu cầu MTU

Kể từ Android 14, ngăn xếp Bluetooth của Android tuân thủ nghiêm ngặt hơn Phiên bản 5.2 của Quy cách lõi Bluetooth và yêu cầu MTU ATT BLE thành 517 byte khi ứng dụng GATT đầu tiên yêu cầu MTU bằng API BluetoothGatt#requestMtu(int) và bỏ qua tất cả các yêu cầu MTU tiếp theo trên kết nối ACL đó.

Để giải quyết thay đổi này và giúp ứng dụng của bạn trở nên mạnh mẽ hơn, hãy cân nhắc các tuỳ chọn sau:

  • Thiết bị ngoại vi của bạn phải phản hồi yêu cầu MTU của thiết bị Android bằng một giá trị hợp lý mà thiết bị ngoại vi có thể chấp nhận. Giá trị đàm phán cuối cùng sẽ là giá trị tối thiểu của giá trị mà Android yêu cầu và giá trị do thiết bị từ xa cung cấp (ví dụ: min(517, remoteMtu))
    • Việc triển khai bản sửa lỗi này có thể yêu cầu cập nhật chương trình cơ sở cho thiết bị ngoại vi
  • Ngoài ra, hãy giới hạn số lần ghi đặc điểm GATT dựa trên giá trị tối thiểu giữa giá trị được hỗ trợ đã biết của thiết bị ngoại vi và thay đổi MTU đã nhận được
    • Xin lưu ý rằng bạn nên giảm 5 byte so với kích thước được hỗ trợ cho tiêu đề
    • Ví dụ: arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5

Lý do mới khiến một ứng dụng có thể được đặt vào bộ chứa chế độ chờ bị hạn chế

Android 14 引入了一种可将应用放入受限待机模式存储分区的新原因。由于 onStartJobonStopJobonBind 方法超时,应用的作业多次触发 ANR 错误。(如需了解对 onStartJobonStopJob 的更改,请参阅 JobScheduler 强化了回调和网络行为。)

如需跟踪应用是否已进入受限待机分桶,我们建议您在作业执行时使用 API UsageStatsManager.getAppStandbyBucket() 进行日志记录,或在应用启动时使用 UsageStatsManager.queryEventsForSelf() 进行日志记录。

mlock giới hạn ở 64 KB

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

Hệ thống thực thi mức sử dụng tài nguyên của ứng dụng được lưu vào bộ nhớ đệm

Theo thiết kế, quy trình của một ứng dụng sẽ ở trạng thái đã lưu vào bộ nhớ đệm khi được chuyển sang chế độ nền và không có thành phần quy trình ứng dụng nào khác đang chạy. Quy trình ứng dụng như vậy có thể sẽ bị tắt do áp lực về bộ nhớ của hệ thống. Khi ở trạng thái này, mọi công việc mà thực thể Activity thực hiện sau khi phương thức onStop() được gọi và trả về đều không đáng tin cậy và không được khuyến khích.

Android 14 đem lại sự nhất quán và biện pháp thực thi cho thiết kế này. Ngay sau khi một quy trình ứng dụng chuyển sang trạng thái đã lưu vào bộ nhớ đệm, công việc ở chế độ nền sẽ không được cho phép, cho đến khi một thành phần quy trình vào lại trạng thái đang hoạt động của vòng đời.

Các ứng dụng có sử dụng API vòng đời được hỗ trợ bởi khung phần mềm thông thường (chẳng hạn như services, JobSchedulerJetpack WorkManager) có thể sẽ không chịu tác động của những thay đổi này.

Trải nghiệm người dùng

Thay đổi về trải nghiệm người dùng đối với thông báo không đóng được

Nếu ứng dụng của bạn cho người dùng thấy thông báo không đóng được, thì nay Android 14 thay đổi hành vi để cho phép người dùng đóng các thông báo như vậy.

Thay đổi này áp dụng cho những ứng dụng ngăn người dùng đóng chế độ nền trước thông báo bằng cách đặt Notification.FLAG_ONGOING_EVENT thông qua Notification.Builder#setOngoing(true) hoặc NotificationCompat.Builder#setOngoing(true). Hành vi của FLAG_ONGOING_EVENT đã được thay đổi để giúp cho người dùng thực sự có thể đóng được các thông báo đó.

Những loại thông báo như vậy vẫn không đóng được trong các điều kiện sau:

  • Khi điện thoại bị khoá
  • Nếu người dùng chọn thao tác Xoá tất cả thông báo (giúp vô tình đóng)

Ngoài ra, hành vi mới này không áp dụng cho các thông báo trong các trường hợp sử dụng sau:

  • CallStyle thông báo
  • Trình kiểm soát chính sách thiết bị (DPC) và các gói hỗ trợ cho doanh nghiệp
  • Thông báo về nội dung nghe nhìn
  • Gói Bộ chọn tìm kiếm mặc định

Thông tin an toàn dữ liệu được trình bày rõ ràng hơn

为了加强用户隐私保护,Android 14 增加了系统显示您在 Play 管理中心表单中声明的信息的位置数量。目前,用户可以在 Google Play 中的应用详情的数据安全部分查看此信息。

我们建议您查看应用的位置数据分享政策,并花一点时间对应用的 Google Play“数据安全”部分进行任何适用的更新。

如需了解详情,请参阅有关如何在 Android 14 上以更显眼的方式显示数据安全信息的指南。

Hỗ trợ tiếp cận

Điều chỉnh tỷ lệ phông chữ phi tuyến tính lên đến 200%

从 Android 14 开始,系统支持将字体放大至最高 200%,为用户提供更多无障碍选项。

如果您已使用可缩放像素 (sp) 单位来定义文本大小,这项更改可能不会对您的应用产生太大影响。不过,您应在启用最大字号 (200%) 的情况下执行界面测试,确保应用能够在不影响易用性的情况下适应较大的字号。

Bảo mật

Cấp API mục tiêu tối thiểu có thể cài đặt

从 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

Tên gói của chủ sở hữu nội dung đa phương tiện có thể bị loại bỏ

媒体库支持查询 OWNER_PACKAGE_NAME 列,该列表示存储特定媒体文件的应用。从 Android 14 开始,除非满足以下条件之一,否则系统会隐去此值:

  • 存储媒体文件的应用有一个软件包名称始终对其他应用可见。
  • 查询媒体库的应用会请求 QUERY_ALL_PACKAGES 权限。

详细了解 Android 如何出于隐私保护目的而过滤软件包可见性