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
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
从 Android 14 开始,当您的应用调用 killBackgroundProcesses()
时,该 API 只能终止您自己应用的后台进程。
如果您传入另一个应用的软件包名称,此方法对该应用的后台进程没有影响,并且 Logcat 中会显示以下消息:
Invalid packageName: com.example.anotherapp
您的应用不应使用 killBackgroundProcesses()
API,也不得以其他方式尝试影响其他应用的进程生命周期,即使在旧版操作系统上也是如此。Android 旨在让缓存应用在后台运行,并在系统需要内存时自动终止它们。如果您的应用会不必要地终止其他应用,则由于之后需要完全重启这些应用,因此可能会降低系统性能并增加耗电量,这比恢复现有缓存应用所消耗的资源要多得多。
MTU được đặt thành 517 cho ứng dụng khách GATT đầu tiên yêu cầu MTU
从 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
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 引入了一种可将应用放入受限待机模式存储分区的新原因。由于 onStartJob
、onStopJob
或 onBind
方法超时,应用的作业多次触发 ANR 错误。(如需了解对 onStartJob
和 onStopJob
的更改,请参阅 JobScheduler 强化了回调和网络行为。)
如需跟踪应用是否已进入受限待机分桶,我们建议您在作业执行时使用 API UsageStatsManager.getAppStandbyBucket()
进行日志记录,或在应用启动时使用 UsageStatsManager.queryEventsForSelf()
进行日志记录。
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 dung lượng bộ nhớ tối đa có thể khoá bằ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 tắc 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 thêm một quy trình 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
从设计上讲,当应用的进程移至后台且没有任何其他应用进程组件在运行时,应用进程将处于缓存状态。此类应用进程可能会因系统内存压力而终止。在此状态下,Activity
实例在调用并返回 onStop()
方法后执行的任何工作均不可靠,强烈建议不要这样做。
Android 14 对此设计引入了一致性和强制执行要求。在应用进程进入缓存状态后不久,系统会禁止后台工作,直到进程组件重新进入生命周期的活跃状态。
使用框架支持的典型生命周期 API(例如服务、JobScheduler
和 Jetpack WorkManager)的应用应该不受这些变化的影响。
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%
Kể từ Android 14, hệ thống sẽ hỗ trợ việc chuyển tỷ lệ phông chữ lên đến 200%, mang đến cho người dùng thị lực kém thêm một số chế độ hỗ trợ tiếp cận phù hợp với Nguyên tắc hỗ trợ tiếp cận nội dung trên web (WCAG).
Nếu bạn đã sử dụng đơn vị pixel được điều chỉnh theo tỷ lệ (sp) để xác định kích thước văn bản, thì thay đổi này có thể sẽ không gây ảnh hưởng lớn đến ứng dụng của bạn. Tuy nhiên, bạn nên kiểm thử giao diện người dùng với kích thước phông chữ tối đa được bật (200%) để đảm bảo ứng dụng có thể đáp ứng kích thước phông chữ lớn hơn mà không ảnh hưởng đến khả năng hữu dụng.
Bảo mật
Cấp API mục tiêu tối thiểu có thể cài đặt
Kể từ Android 14, người dùng không thể cài đặt ứng dụng có targetSdkVersion
thấp hơn 23. Việc yêu cầu ứng dụng đáp ứng các yêu cầu tối thiểu về cấp độ API mục tiêu giúp cải thiện khả năng bảo vệ quyền riêng tư và bảo mật cho người dùng.
Các phần mềm độc hại thường nhắm đến các cấp độ API cũ để né tránh các biện pháp bảo vệ quyền riêng tư và bảo mật được ra mắt trong các phiên bản Android mới. Ví dụ: một số ứng dụng độc hại sử dụng targetSdkVersion
22 để tránh phải tuân theo mô hình quản lý quyền khi bắt đầu chạy ra mắt năm 2015 trên Android 6.0 Marshmallow (API cấp 23). Thay đổi này trên Android 14 giúp cải thiện khả năng bảo vệ quyền riêng tư và bảo mật, khiến phần mềm độc hại khó lòng qua mặt được.
Việc cố gắng cài đặt một ứng dụng nhắm đến cấp độ API thấp hơn sẽ dẫn đến lỗi cài đặt và thông báo sau đây sẽ xuất hiện trong Logcat:
INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 23, but found 7
Trên các thiết bị nâng cấp lên Android 14, mọi ứng dụng có targetSdkVersion
thấp hơn 23 đã cài đặt vẫn được duy trì.
Nếu cần kiểm thử một ứng dụng nhắm đến cấp độ API cũ hơn, hãy dùng lệnh ADB sau đây:
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 如何出于隐私保护目的而过滤软件包可见性。