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 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
On Android 14, the system can place context-registered broadcasts in a queue while the app is in the cached state. This is similar to the queuing behavior that Android 12 (API level 31) introduced for async binder transactions. Manifest-declared broadcasts aren't queued, and apps are removed from the cached state for broadcast delivery.
When the app leaves the cached state, such as returning to the foreground, the system delivers any queued broadcasts. Multiple instances of certain broadcasts might be merged into one broadcast. Depending on other factors, such as system health, apps might be removed from the cached state, and any previously queued broadcasts are delivered.
Ứ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
Starting from Android 14, the Android Bluetooth stack more strictly adheres to
Version 5.2 of the Bluetooth Core Specification and requests
the BLE ATT MTU to 517 bytes when the first GATT client requests an MTU using
the BluetoothGatt#requestMtu(int)
API, and disregards all subsequent MTU
requests on that ACL connection.
To address this change and make your app more robust, consider the following options:
- Your peripheral device should respond to the Android device's MTU request
with a reasonable value that can be accommodated by the peripheral. The
final negotiated value will be a minimum of the Android requested value and
the remote provided value (for example,
min(517, remoteMtu)
)- Implementing this fix could require a firmware update for peripheral
- Alternatively, limit your GATT characteristic writes based on the minimum
between the known supported value of your peripheral and the received MTU
change
- A reminder that you should reduce 5 bytes from the supported size for the headers
- For example:
arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5
Lý do mới khiến ứng dụng có thể bị đặ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
Trong Android 14 (API cấp 34) trở lên, nền tảng này giảm bộ nhớ tối đa có thể bị khoá bằng cách sử dụng mlock()
xuống còn 64 KB cho mỗi quy trình. Trong các phiên bản trước, giới hạn là 64 MB cho mỗi quy trình. Quy định hạn chế này giúp quản lý bộ nhớ hiệu quả hơn trên các ứng dụng và hệ thống. Để mang lại tính nhất quán hơn trên các thiết bị, Android 14 bổ sung một bài kiểm thử CTS mới cho giới hạn mlock()
mới trên các thiết bị tương thích.
Hệ thống thực thi việc sử dụng tài nguyên ứ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
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
Để 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 low-vision users with additional accessibility options that align with Web Content Accessibility Guidelines (WCAG).
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ỏ
The media store supports queries for the OWNER_PACKAGE_NAME
column, which
indicates the app that stored a particular media file. Starting in Android
14, this value is redacted unless at least one of the following conditions is
true:
- The app that stored the media file has a package name that is always visible to other apps.
The app that queries the media store requests the
QUERY_ALL_PACKAGES
permission.
Learn more about how Android filters package visibility for privacy purposes.