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

Chuông báo chính xác là tính năng dành cho các thông báo mà người dùng có ý định thực hiện, hoặc hành động cần thực hiện tại một thời điểm chính xác. Kể từ Android 14, quyền SCHEDULE_EXACT_ALARM sẽ không còn được cấp trước cho những ứng dụng mới cài đặt nhắm đến Android 13 trở lên (quyền này bị từ chối theo mặc định).

Tìm hiểu thêm về những thay đổi đối với quyền lên lịch chuông báo chính xác.

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 introduces a new reason an app can be placed into the restricted standby bucket. The app's jobs trigger ANR errors multiple times due to onStartJob, onStopJob, or onBind method timeouts. (See JobScheduler reinforces callback and network behavior for changes to onStartJob and onStopJob.)

To track whether or not the app has entered the restricted standby bucket, we recommend logging with the API UsageStatsManager.getAppStandbyBucket() on job execution or UsageStatsManager.queryEventsForSelf() on app startup.

mlock giới hạn ở 64 KB

In Android 14 (API level 34) and higher, the platform reduces the maximum memory that can be locked using mlock() to 64 KB per process. In previous versions, the limit was 64 MB per process. This restriction promotes better memory management across apps and the system. To provide more consistency across devices, Android 14 adds a new CTS test for the new mlock() limit on compatible devices.

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

By design, an app's process is in a cached state when it's moved to the background and no other app process components are running. Such an app process is subject to being killed due to system memory pressure. Any work that Activity instances perform after the onStop() method has been called and returned, while in this state, is unreliable and strongly discouraged.

Android 14 introduces consistency and enforcement to this design. Shortly after an app process enters a cached state, background work is disallowed, until a process component re-enters an active state of the lifecycle.

Apps that use typical framework-supported lifecycle APIs – such as services, JobScheduler, and Jetpack WorkManager – shouldn't be impacted by these changes.

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

If your app shows non-dismissable foreground notifications to users, Android 14 has changed the behavior to allow users to dismiss such notifications.

This change applies to apps that prevent users from dismissing foreground notifications by setting Notification.FLAG_ONGOING_EVENT through Notification.Builder#setOngoing(true) or NotificationCompat.Builder#setOngoing(true). The behavior of FLAG_ONGOING_EVENT has changed to make such notifications actually dismissable by the user.

These kinds of notifications are still non-dismissable in the following conditions:

  • When the phone is locked
  • If the user selects a Clear all notification action (which helps with accidental dismissals)

Also, this new behavior doesn't apply to notifications in the following use cases:

  • CallStyle notifications
  • Device policy controller (DPC) and supporting packages for enterprise
  • Media notifications
  • The default Search Selector package

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

Để tăng cường bảo vệ quyền riêng tư của người dùng, Android 14 cho thấy thông tin bạn đã khai báo trong biểu mẫu trên Play Console ở nhiều nơi hơn. Hiện tại, người dùng có thể xem thông tin này trong mục An toàn dữ liệu tại trang thông tin của ứng dụng của bạn trên Google Play.

Bạn nên tham khảo các chính sách về việc chia sẻ dữ liệu vị trí của ứng dụng và cập nhật mục An toàn dữ liệu trên Google Play cho ứng dụng của mình (nếu có).

Tìm hiểu thêm trong hướng dẫn về cách trình bày thông tin an toàn dữ liệu rõ ràng hơn trên 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%

Starting in Android 14, the system supports font scaling up to 200%, providing users with additional accessibility options.

If you already use scaled pixels (sp) units to define text sizing, then this change probably won't have a high impact on your app. However, you should perform UI testing with the maximum font size enabled (200%) to ensure that your app can accommodate larger font sizes without impacting usability.

Bảo mật

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

Starting with Android 14, apps with a targetSdkVersion lower than 23 can't be installed. Requiring apps to meet these minimum target API level requirements improves security and privacy for users.

Malware often targets older API levels in order to bypass security and privacy protections that have been introduced in newer Android versions. For example, some malware apps use a targetSdkVersion of 22 to avoid being subjected to the runtime permission model introduced in 2015 by Android 6.0 Marshmallow (API level 23). This Android 14 change makes it harder for malware to avoid security and privacy improvements. Attempting to install an app targeting a lower API level will result in an installation failure, with the following message appearing in Logcat:

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

On devices upgrading to Android 14, any apps with a targetSdkVersion lower than 23 will remain installed.

If you need to test an app targeting an older API level, use the following ADB command:

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ỏ

Kho nội dung đa phương tiện hỗ trợ truy vấn cho cột OWNER_PACKAGE_NAME (cho biết rằng ứng dụng đã lưu trữ một tệp đa phương tiện cụ thể). Kể từ Android 14, giá trị này sẽ bị loại bỏ, trừ phi có ít nhất một trong các điều kiện sau:

  • Ứng dụng lưu trữ tệp đa phương tiện có tên gói luôn cho các ứng dụng khác thấy.
  • Ứng dụng truy vấn kho nội dung đa phương tiện yêu cầu quyền QUERY_ALL_PACKAGES.

Tìm hiểu thêm về cách Android lọc chế độ hiển thị gói cho mục đích bảo vệ quyền riêng tư.