Platform Android 14 menyertakan perubahan perilaku yang mungkin memengaruhi aplikasi Anda.
Perubahan perilaku berikut ini berlaku untuk semua aplikasi saat dijalankan di Android 14,
terlepas dari
targetSdkVersion
. Sebaiknya
uji aplikasi Anda lalu modifikasi sesuai kebutuhan untuk mendukung perubahan ini dengan tepat, jika
memungkinkan.
Selain itu, pastikan Anda meninjau daftar perubahan perilaku yang hanya memengaruhi aplikasi yang menargetkan Android 14.
Fungsi inti
Menjadwalkan alarm yang tepat ditolak secara default
Alarm yang tepat dimaksudkan untuk notifikasi yang ditujukan bagi pengguna, atau untuk tindakan yang
perlu terjadi pada waktu yang tepat. Mulai Android 14, izin
SCHEDULE_EXACT_ALARM
tidak lagi diberikan kepada sebagian besar aplikasi terinstal baru yang menargetkan
Android 13 dan yang lebih tinggi—izin ditolak secara default.
Pelajari lebih lanjut perubahan izin untuk penjadwalan alarm yang tepat.
Siaran yang terdaftar dalam konteks dimasukkan ke dalam antrean saat aplikasi di-cache
Di Android 14, sistem dapat menempatkan siaran yang terdaftar dalam konteks ke dalam antrean saat aplikasi dalam status cache. Ini mirip dengan perilaku antrean yang diperkenalkan oleh Android 12 (API level 31) untuk transaksi binder asinkron. Siaran yang dideklarasikan manifes tidak dimasukkan dalam antrean, dan aplikasi dihapus dari status cache untuk pengiriman siaran.
Saat aplikasi keluar dari status yang di-cache, misalnya kembali ke latar depan, sistem akan mengirim siaran dalam antrean. Beberapa instance siaran tertentu mungkin digabungkan menjadi satu siaran. Tergantung pada faktor lain, seperti sistem aplikasi mungkin dihapus dari status cache, dan aplikasi apa pun yang sebelumnya dimasukkan ke dalam antrean siaran tetap dikirimkan.
Aplikasi hanya dapat menghentikan proses latar belakangnya sendiri
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 ditetapkan ke 517 untuk klien GATT pertama yang meminta 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
Alasan baru aplikasi dapat ditempatkan di bucket standby terbatas
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 dibatasi hingga 64 KB
Di Android 14 (level API 34) dan yang lebih baru, platform mengurangi memori maksimum
yang dapat dikunci menggunakan mlock()
menjadi 64 KB per proses. Pada
versi sebelumnya, batasnya adalah 64 MB per proses. Pembatasan ini
meningkatkan manajemen memori yang lebih baik di seluruh aplikasi dan sistem. Agar lebih
konsisten di seluruh perangkat, Android 14 menambahkan pengujian CTS baru untuk
batas mlock()
baru pada perangkat yang kompatibel.
Sistem menerapkan penggunaan resource aplikasi yang di-cache
Menurut desain, proses aplikasi berada dalam status cache saat dipindahkan ke
latar belakang dan tidak ada komponen proses aplikasi lain yang berjalan. Proses aplikasi
tersebut dapat dihentikan karena tekanan memori sistem. Setiap pekerjaan yang
dilakukan oleh instance Activity
setelah metode onStop()
dipanggil dan
ditampilkan, dalam keadaan ini tidak dapat diandalkan dan sangat tidak disarankan.
Android 14 memperkenalkan konsistensi dan penerapan dalam desain ini. Segera setelah proses aplikasi memasuki status cache, pekerjaan latar belakang tidak diizinkan, sampai komponen proses memasuki kembali status aktif siklus proses.
Aplikasi yang menggunakan API siklus proses yang didukung framework standar, seperti
layanan, JobScheduler
, dan Jetpack WorkManager, tidak akan
terpengaruh oleh perubahan ini.
Pengalaman pengguna
Perubahan pada cara pengguna menerima notifikasi yang tidak dapat ditutup
Jika aplikasi Anda menampilkan notifikasi latar depan yang tidak dapat ditutup kepada pengguna, Android 14 telah mengubah perilaku itu untuk memungkinkan pengguna menutup notifikasi tersebut.
Perubahan ini berlaku untuk aplikasi yang mencegah pengguna menutup latar depan
notifikasi dengan menyetel Notification.FLAG_ONGOING_EVENT
melalui
Notification.Builder#setOngoing(true)
atau
NotificationCompat.Builder#setOngoing(true)
. Perilaku
FLAG_ONGOING_EVENT
telah berubah untuk membuat notifikasi tersebut
benar-benar dapat ditutup oleh pengguna.
Jenis notifikasi ini masih tidak dapat ditutup dalam kondisi berikut:
- Saat ponsel dikunci
- Jika pengguna memilih tindakan notifikasi Hapus semua (yang membantu mencegah penutupan yang tidak disengaja)
Selain itu, perilaku baru ini tidak berlaku untuk notifikasi di kasus penggunaan berikut:
- Notifikasi
CallStyle
- Pengontrol kebijakan perangkat (DPC) dan paket pendukung untuk perusahaan
- Notifikasi media
- Paket Pemilih Penelusuran default
Informasi keamanan data terlihat lebih jelas
Untuk meningkatkan privasi pengguna, Android 14 meningkatkan jumlah tempat sistem menampilkan informasi yang telah Anda deklarasikan dalam formulir Konsol Play. Saat ini, pengguna dapat melihat informasi ini di bagian Keamanan data di listingan aplikasi Anda di Google Play.
Sebaiknya Anda meninjau kebijakan berbagi data lokasi aplikasi dan meluangkan waktu untuk melakukan update yang berlaku pada bagian Keamanan Data Google Play di aplikasi Anda.
Pelajari lebih lanjut dalam panduan tentang bagaimana informasi keamanan data lebih terlihat di Android 14.
Aksesibilitas
Penskalaan font non-linear ke 200%
Mulai Android 14, sistem mendukung penskalaan font hingga 200%, yang memberikan opsi aksesibilitas tambahan kepada pengguna yang mengalami gangguan penglihatan, sesuai dengan Pedoman Aksesibilitas Konten Web (WCAG).
Jika Anda telah menggunakan unit piksel yang diskalakan (sp) untuk menentukan ukuran teks, perubahan ini mungkin tidak akan memiliki dampak tinggi pada aplikasi Anda. Namun, Anda harus melakukan pengujian UI dengan ukuran font maksimum yang diaktifkan (200%) untuk memastikan aplikasi Anda dapat mengakomodasi ukuran font yang lebih besar tanpa memengaruhi kegunaan.
Keamanan
API level target minimum yang dapat diinstal
Mulai Android 14, aplikasi dengan
targetSdkVersion
di bawah 23
tidak dapat diinstal. Mewajibkan aplikasi memenuhi persyaratan API level target minimum
akan meningkatkan keamanan dan privasi bagi pengguna.
Malware sering kali menargetkan API level lama untuk mengabaikan perlindungan
privasi dan keamanan yang telah diperkenalkan dalam versi Android yang lebih baru. Misalnya,
beberapa aplikasi malware menggunakan targetSdkVersion
dari 22 agar tidak dikenai
model izin runtime yang diperkenalkan pada tahun 2015 oleh Android 6.0 Marshmallow (API
level 23). Perubahan Android 14 ini mempersulit malware untuk menghindari peningkatan
keamanan dan privasi.
Mencoba menginstal aplikasi yang menargetkan API level yang lebih rendah akan mengakibatkan
kegagalan penginstalan, dengan pesan berikut muncul di Logcat:
INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 23, but found 7
Pada perangkat yang diupgrade ke Android 14, aplikasi dengan targetSdkVersion
yang lebih rendah dari 23 akan tetap diinstal.
Jika Anda perlu menguji aplikasi yang menargetkan API level lama, gunakan perintah ADB berikut:
adb install --bypass-low-target-sdk-block FILENAME.apk
Nama paket pemilik media mungkin akan disamarkan
Penyimpanan media mendukung kueri untuk kolom OWNER_PACKAGE_NAME
, yang
menunjukkan aplikasi yang menyimpan file media tertentu. Mulai Android
14, nilai ini disamarkan kecuali jika setidaknya salah satu kondisi berikut
terpenuhi:
- Aplikasi yang menyimpan file media memiliki nama paket yang selalu terlihat oleh aplikasi lain.
Aplikasi yang mengkueri penyimpanan media meminta izin
QUERY_ALL_PACKAGES
.
Pelajari lebih lanjut cara Android memfilter visibilitas paket untuk tujuan privasi.