Perubahan perilaku: semua aplikasi

Platform Android 14 menyertakan perubahan perilaku yang mungkin memengaruhi aplikasi Anda. Perubahan perilaku berikut 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 dalam antrean saat aplikasi berada 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 dapat digabungkan menjadi satu siaran. Bergantung pada faktor lain, seperti kesehatan sistem, aplikasi mungkin dihapus dari status cache, dan siaran dalam antrean sebelumnya akan dikirimkan.

Aplikasi hanya dapat menghentikan proses latar belakangnya sendiri

Mulai Android 14, saat aplikasi memanggil killBackgroundProcesses(), API hanya dapat menghentikan proses latar belakang aplikasi Anda sendiri.

Jika Anda meneruskan nama paket aplikasi lain, metode ini tidak akan memengaruhi proses latar belakang aplikasi tersebut, dan pesan berikut akan muncul di Logcat:

Invalid packageName: com.example.anotherapp

Aplikasi Anda tidak boleh menggunakan killBackgroundProcesses() API atau mencoba memengaruhi siklus proses aplikasi lain, bahkan pada versi OS yang lebih lama. Android didesain untuk menyimpan aplikasi yang di-cache di latar belakang dan menghentikannya secara otomatis saat sistem memerlukan memori. Jika aplikasi Anda menghentikan aplikasi lain secara tidak perlu, hal tersebut dapat mengurangi performa sistem dan meningkatkan konsumsi baterai dengan mewajibkan aplikasi tersebut dimulai ulang sepenuhnya, yang memerlukan lebih banyak resource secara signifikan daripada melanjutkan aplikasi yang ada di cache.

MTU ditetapkan ke 517 untuk klien GATT pertama yang meminta MTU

Mulai dari Android 14, stack Bluetooth Android secara ketat mematuhi Spesifikasi Bluetooth Core Versi 5.2 dan meminta MTU BLE ATT hingga 517 byte saat klien GATT pertama meminta MTU menggunakan BluetoothGatt#requestMtu(int) API, dan mengabaikan semua permintaan MTU berikutnya pada koneksi ACL tersebut.

Untuk mengatasi perubahan ini dan membuat aplikasi Anda lebih tangguh, pertimbangkan opsi berikut:

  • Perangkat periferal Anda harus merespons permintaan MTU perangkat Android dengan nilai yang wajar yang dapat diakomodasi oleh periferal. Nilai akhir yang dinegosiasikan akan berupa minimum dari nilai yang diminta Android dan nilai yang diberikan jarak jauh (misalnya, min(517, remoteMtu))
    • Menerapkan perbaikan ini dapat memerlukan update firmware untuk periferal
  • Atau, batasi penulisan karakteristik GATT Anda berdasarkan nilai minimum antara nilai periferal yang didukung yang diketahui dan perubahan MTU yang diterima
    • Perlu diingat bahwa Anda harus mengurangi 5 byte dari ukuran yang didukung untuk header
    • Contoh: arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5

Alasan baru aplikasi dapat ditempatkan di bucket standby terbatas

Android 14 memperkenalkan alasan baru untuk menempatkan aplikasi ke dalam bucket standby yang dibatasi. Tugas aplikasi memicu error ANR beberapa kali karena waktu tunggu metode onStartJob, onStopJob, atau onBind. (Lihat JobScheduler memperkuat perilaku jaringan dan callback untuk perubahan pada onStartJob dan onStopJob.)

Untuk melacak apakah aplikasi telah memasuki bucket standby yang dibatasi atau tidak, sebaiknya logging dengan API UsageStatsManager.getAppStandbyBucket() saat eksekusi tugas atau UsageStatsManager.queryEventsForSelf() saat aplikasi dimulai.

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 memberlakukan penggunaan resource aplikasi yang di-cache

从设计上讲,当应用的进程移至后台且没有任何其他应用进程组件在运行时,应用进程将处于缓存状态。此类应用进程可能会因系统内存压力而终止。在此状态下,Activity 实例在调用并返回 onStop() 方法后执行的任何工作均不可靠,强烈建议不要这样做。

Android 14 对此设计引入了一致性和强制执行要求。在应用进程进入缓存状态后不久,系统会禁止后台工作,直到进程组件重新进入生命周期的活跃状态。

使用框架支持的典型生命周期 API(例如服务JobSchedulerJetpack WorkManager)的应用应该不受这些变化的影响。

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 notifikasi latar depan dengan menetapkan 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 dalam 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%

从 Android 14 开始,系统支持字体放大高达 200%,为弱视用户提供了符合网络内容无障碍指南 (WCAG) 的其他无障碍功能选项。

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

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

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.