Perubahan perilaku: semua aplikasi

Platform Android 16 menyertakan perubahan perilaku yang mungkin memengaruhi aplikasi Anda. Perubahan perilaku berikut ini berlaku untuk semua aplikasi saat dijalankan di Android 16, terlepas dari targetSdkVersion. Sebaiknya uji aplikasi Anda, lalu modifikasi sesuai kebutuhan untuk mendukung perubahan ini, jika memungkinkan.

Selain itu, pastikan Anda meninjau daftar perubahan perilaku yang hanya memengaruhi aplikasi yang menargetkan Android 16.

Fungsi inti

Android 16 (level API 36) mencakup perubahan berikut yang mengubah atau memperluas berbagai kemampuan inti sistem Android.

Pengoptimalan kuota JobScheduler

Starting in Android 16, we're adjusting regular and expedited job execution runtime quota based on the following factors:

  • Which app standby bucket the application is in: in Android 16, active standby buckets will start being enforced by a generous runtime quota.
  • If the job starts execution while the app is in a top state: in Android 16, Jobs started while the app is visible to the user and continues after the app becomes invisible, will adhere to the job runtime quota.
  • If the job is executing while running a Foreground Service: in Android 16, jobs that are executing while concurrently with a foreground service will adhere to the job runtime quota. If you're leveraging jobs for user initiated data transfer, consider using user initiated data transfer jobs instead.

This change impacts tasks scheduled using WorkManager, JobScheduler, and DownloadManager. To debug why a job was stopped, we recommend logging why your job was stopped by calling WorkInfo.getStopReason() (for JobScheduler jobs, call JobParameters.getStopReason()).

For information about how your app's state affects the resources it can use, see Power management resource limits. For more information on battery-optimal best practices, refer to guidance on optimize battery use for task scheduling APIs.

We also recommend leveraging the new JobScheduler#getPendingJobReasonsHistory API introduced in Android 16 to understand why a job has not executed.

Testing

To test your app's behavior, you can enable override of certain job quota optimizations as long as the app is running on an Android 16 device.

To disable enforcement of "top state will adhere to job runtime quota", run the following adb command:

adb shell am compat enable OVERRIDE_QUOTA_ENFORCEMENT_TO_TOP_STARTED_JOBS APP_PACKAGE_NAME

To disable enforcement of "jobs that are executing while concurrently with a foreground service will adhere to the job runtime quota", run the following adb command:

adb shell am compat enable OVERRIDE_QUOTA_ENFORCEMENT_TO_FGS_JOBS APP_PACKAGE_NAME

To test certain app standby bucket behavior, you can set the app standby bucket of your app using the following adb command:

adb shell am set-standby-bucket APP_PACKAGE_NAME active|working_set|frequent|rare|restricted

To understand the app standby bucket your app is in, you can get the app standby bucket of your app using the following adb command:

adb shell am get-standby-bucket APP_PACKAGE_NAME

Alasan penghentian tugas kosong yang ditinggalkan

Tugas yang ditinggalkan terjadi saat objek JobParameters yang terkait dengan tugas telah dibersihkan sampah memorinya, tetapi JobService#jobFinished(JobParameters, boolean) belum dipanggil untuk menandakan penyelesaian tugas. Hal ini menunjukkan bahwa tugas mungkin sedang berjalan dan dijadwalkan ulang tanpa sepengetahuan aplikasi.

Aplikasi yang mengandalkan JobScheduler, tidak mempertahankan referensi yang kuat ke objek JobParameters, dan waktu tunggu kini akan diberi alasan penghentian tugas baru STOP_REASON_TIMEOUT_ABANDONED, bukan STOP_REASON_TIMEOUT.

Jika alasan perhentian yang ditinggalkan baru sering terjadi, sistem akan mengambil langkah mitigasi untuk mengurangi frekuensi tugas.

Aplikasi harus menggunakan alasan penghentian baru untuk mendeteksi dan mengurangi tugas yang ditinggalkan.

Jika menggunakan WorkManager, AsyncTask, atau DownloadManager, Anda tidak akan terpengaruh karena API ini mengelola siklus proses tugas atas nama aplikasi Anda.

Menghentikan penggunaan JobInfo#setImportantWhileForeground sepenuhnya

The JobInfo.Builder#setImportantWhileForeground(boolean) method indicates the importance of a job while the scheduling app is in the foreground or when temporarily exempted from background restrictions.

This method has been deprecated since Android 12 (API level 31). Starting in Android 16, it no longer functions effectively and calling this method will be ignored.

This removal of functionality also applies to JobInfo#isImportantWhileForeground(). Starting in Android 16, if the method is called, the method returns false.

Cakupan prioritas siaran berurutan tidak lagi global

Aplikasi Android diizinkan untuk menentukan prioritas pada penerima siaran untuk mengontrol urutan penerima menerima dan memproses siaran. Untuk penerima yang dideklarasikan dalam manifes, aplikasi dapat menggunakan atribut android:priority untuk menentukan prioritas dan untuk penerima yang terdaftar dalam konteks, aplikasi dapat menggunakan IntentFilter#setPriority() API untuk menentukan prioritas. Saat siaran dikirim, sistem akan mengirimkannya ke penerima sesuai urutan prioritasnya, dari yang tertinggi ke yang terendah.

Di Android 16, urutan pengiriman siaran menggunakan atribut android:priority atau IntentFilter#setPriority() di berbagai proses tidak akan dijamin. Prioritas siaran hanya akan dihormati dalam proses aplikasi yang sama, bukan di semua proses.

Selain itu, prioritas siaran akan otomatis dibatasi pada rentang (SYSTEM_LOW_PRIORITY + 1, SYSTEM_HIGH_PRIORITY - 1). Hanya komponen sistem yang akan diizinkan untuk menetapkan SYSTEM_LOW_PRIORITY, SYSTEM_HIGH_PRIORITY sebagai prioritas siaran.

Aplikasi Anda mungkin terpengaruh jika melakukan salah satu hal berikut:

  1. Aplikasi Anda telah mendeklarasikan beberapa proses dengan intent siaran yang sama, dan memiliki ekspektasi seputar penerimaan intent tersebut dalam urutan tertentu berdasarkan prioritas.
  2. Proses aplikasi Anda berinteraksi dengan proses lain dan memiliki ekspektasi tentang menerima intent siaran dalam urutan tertentu.

Jika proses perlu berkoordinasi satu sama lain, proses tersebut harus berkomunikasi menggunakan saluran koordinasi lain.

Perubahan internal ART

Android 16 menyertakan update terbaru ke Android Runtime (ART) yang meningkatkan performa Android Runtime (ART) dan memberikan dukungan untuk fitur Java tambahan. Melalui update Sistem Google Play, peningkatan ini juga tersedia untuk lebih dari satu miliar perangkat yang menjalankan Android 12 (API level 31) dan yang lebih tinggi.

Saat perubahan ini dirilis, library dan kode aplikasi yang mengandalkan struktur internal ART mungkin tidak berfungsi dengan benar di perangkat yang menjalankan Android 16, beserta versi Android sebelumnya yang mengupdate modul ART melalui update sistem Google Play.

Mengandalkan struktur internal (seperti antarmuka non-SDK) dapat selalu menyebabkan masalah kompatibilitas, tetapi sangat penting untuk menghindari mengandalkan kode (atau library yang berisi kode) yang memanfaatkan struktur ART internal, karena perubahan ART tidak terikat dengan versi platform yang dijalankan perangkat dan perubahan tersebut dikirim ke lebih dari satu miliar perangkat melalui update sistem Google Play.

Semua developer harus memeriksa apakah aplikasi mereka terpengaruh dengan menguji aplikasi secara menyeluruh di Android 16. Selain itu, periksa masalah umum untuk mengetahui apakah aplikasi Anda bergantung pada library yang telah kami identifikasi yang mengandalkan struktur ART internal. Jika Anda memiliki kode aplikasi atau dependensi library yang terpengaruh, cari alternatif API publik jika memungkinkan dan minta API publik untuk kasus penggunaan baru dengan membuat permintaan fitur di issue tracker kami.

Mode kompatibilitas ukuran halaman 16 KB

Android 15 memperkenalkan dukungan untuk halaman memori 16 KB guna mengoptimalkan performa platform. Android 16 menambahkan mode kompatibilitas, yang memungkinkan beberapa aplikasi yang di-build untuk halaman memori 4 KB berjalan di perangkat yang dikonfigurasi untuk halaman memori 16 KB.

Saat aplikasi Anda berjalan di perangkat dengan Android 16 atau yang lebih tinggi, jika Android mendeteksi bahwa aplikasi Anda memiliki halaman memori yang diselaraskan 4 KB, aplikasi akan otomatis menggunakan mode kompatibilitas dan menampilkan dialog notifikasi kepada pengguna. Menetapkan properti android:pageSizeCompat di AndroidManifest.xml untuk mengaktifkan mode kompatibilitas mundur akan mencegah tampilan dialog saat aplikasi diluncurkan. Untuk menggunakan properti android:pageSizeCompat, kompilasi aplikasi Anda menggunakan Android 16 SDK.

Untuk performa, keandalan, dan stabilitas terbaik, aplikasi Anda harus tetap selaras dengan 16 KB. Lihat postingan blog terbaru kami tentang mengupdate aplikasi Anda untuk mendukung halaman memori 16 KB guna mengetahui detail selengkapnya.

Dialog mode kompatibilitas yang ditampilkan saat sistem mendeteksi bahwa aplikasi yang selaras dengan 4 KB dapat berjalan lebih optimal jika 16 KB selaras.

Pengalaman pengguna dan UI sistem

Android 16 (level API 36) menyertakan perubahan berikut yang dimaksudkan untuk menciptakan pengalaman pengguna yang lebih konsisten dan intuitif.

Penghentian pengumuman aksesibilitas yang mengganggu

Android 16 tidak lagi menggunakan pengumuman aksesibilitas, yang ditandai dengan penggunaan announceForAccessibility atau pengiriman peristiwa aksesibilitas TYPE_ANNOUNCEMENT. Hal ini dapat membuat pengalaman pengguna yang tidak konsisten bagi pengguna TalkBack dan pembaca layar Android, dan alternatifnya lebih baik memenuhi berbagai kebutuhan pengguna di berbagai teknologi asistif Android.

Contoh alternatif:

Dokumentasi referensi untuk announceForAccessibility API yang tidak digunakan lagi menyertakan detail selengkapnya tentang alternatif yang disarankan.

Dukungan untuk navigasi 3 tombol

Android 16 menghadirkan dukungan kembali prediktif ke navigasi 3 tombol untuk aplikasi yang telah dimigrasikan dengan benar ke kembali prediktif. Menekan lama tombol kembali akan memulai animasi kembali prediktif, yang memberi Anda pratinjau tempat geser kembali akan membawa Anda.

Perilaku ini berlaku di semua area sistem yang mendukung animasi kembali prediktif, termasuk animasi sistem (kembali ke layar utama, lintas tugas, dan lintas aktivitas).

Animasi kembali prediktif dalam mode navigasi 3 tombol.

Faktor bentuk perangkat

Android 16 (level API 36) menyertakan perubahan berikut untuk aplikasi saat diproyeksikan ke layar oleh pemilik perangkat virtual.

Penggantian pemilik perangkat virtual

Pemilik perangkat virtual adalah aplikasi tepercaya atau istimewa yang membuat dan mengelola perangkat virtual. Pemilik perangkat virtual menjalankan aplikasi di perangkat virtual, lalu memproyeksikan aplikasi ke layar perangkat jarak jauh, seperti komputer pribadi, perangkat virtual reality, atau sistem infotainment mobil. Pemilik perangkat virtual berada di perangkat lokal, seperti ponsel.

Pemilik perangkat virtual di ponsel membuat perangkat virtual yang memproyeksikan aplikasi ke layar jarak jauh.

Penggantian per aplikasi

Di perangkat yang menjalankan Android 16 (level API 36), pemilik perangkat virtual dapat mengganti setelan aplikasi di perangkat virtual tertentu yang dikelola pemilik perangkat virtual. Misalnya, untuk meningkatkan tata letak aplikasi, pemilik perangkat virtual dapat mengabaikan batasan orientasi, rasio aspek, dan kemampuan pengubahan ukuran saat memproyeksikan aplikasi ke layar eksternal.

Perubahan umum yang dapat menyebabkan gangguan

Perilaku Android 16 dapat memengaruhi UI aplikasi Anda pada faktor bentuk layar besar seperti layar mobil atau Chromebook, terutama tata letak yang dirancang untuk layar kecil dalam orientasi potret. Untuk mempelajari cara membuat aplikasi Anda adaptif untuk semua faktor bentuk perangkat, lihat Tentang tata letak adaptif.

Referensi

Streaming aplikasi pendamping

Keamanan

Android 16 (level API 36) menyertakan perubahan yang meningkatkan keamanan sistem untuk membantu melindungi aplikasi dan pengguna dari aplikasi berbahaya.

Peningkatan keamanan terhadap serangan pengalihan Intent

Android 16 provides default security against general Intent redirection attacks, with minimum compatibility and developer changes required.

We are introducing by-default security hardening solutions to Intent redirection exploits. In most cases, apps that use intents normally won't experience any compatibility issues; we've gathered metrics throughout our development process to monitor which apps might experience breakages.

Intent redirection in Android occurs when an attacker can partly or fully control the contents of an intent used to launch a new component in the context of a vulnerable app, while the victim app launches an untrusted sub-level intent in an extras field of an ("top-level") Intent. This can lead to the attacker app launching private components in the context of the victim app, triggering privileged actions, or gaining URI access to sensitive data, potentially leading to data theft and arbitrary code execution.

Opt out of Intent redirection handling

Android 16 introduces a new API that allows apps to opt out of launch security protections. This might be necessary in specific cases where the default security behavior interferes with legitimate app use cases.

For applications compiling against Android 16 (API level 36) SDK or higher

You can directly use the removeLaunchSecurityProtection() method on the Intent object.

val i = intent
val iSublevel: Intent? = i.getParcelableExtra("sub_intent")
iSublevel?.removeLaunchSecurityProtection() // Opt out from hardening
iSublevel?.let { startActivity(it) }
For applications compiling against Android 15 (API level 35) or lower

While not recommended, you can use reflection to access the removeLaunchSecurityProtection() method.

val i = intent
val iSublevel: Intent? = i.getParcelableExtra("sub_intent", Intent::class.java)
try {
    val removeLaunchSecurityProtection = Intent::class.java.getDeclaredMethod("removeLaunchSecurityProtection")
    removeLaunchSecurityProtection.invoke(iSublevel)
} catch (e: Exception) {
    // Handle the exception, e.g., log it
} // Opt-out from the security hardening using reflection
iSublevel?.let { startActivity(it) }

Aplikasi pendamping tidak lagi diberi tahu tentang waktu tunggu penemuan

Android 16 introduces a new behavior during companion device pairing flow to protect the user's location privacy from malicious apps. All companion apps running on Android 16 are no longer directly notified of discovery timeout using RESULT_DISCOVERY_TIMEOUT. Instead, the user is notified of timeout events with a visual dialog. When the user dismisses the dialog, the app is alerted of the association failure with RESULT_USER_REJECTED.

The search duration has also been extended from the original 20 seconds, and the device discovery can be stopped by the user at any point during the search. If at least one device was discovered within the first 20 seconds of starting the search, the CDM stops searching for additional devices.

Konektivitas

Android 16 (level API 36) menyertakan perubahan berikut dalam stack Bluetooth untuk meningkatkan konektivitas dengan perangkat periferal.

Peningkatan penanganan kehilangan ikatan

Mulai Android 16, stack Bluetooth telah diupdate untuk meningkatkan keamanan dan pengalaman pengguna saat kehilangan ikatan jarak jauh terdeteksi. Sebelumnya, sistem akan otomatis menghapus ikatan dan memulai proses penyambungan baru, yang dapat menyebabkan penyambungan ulang yang tidak disengaja. Kami telah melihat dalam banyak kasus aplikasi tidak menangani peristiwa kehilangan ikatan secara konsisten.

Untuk menyatukan pengalaman, Android 16 meningkatkan penanganan kehilangan ikatan ke sistem. Jika perangkat Bluetooth yang sebelumnya tersambung tidak dapat diautentikasi setelah terhubung kembali, sistem akan memutuskan hubungan link, mempertahankan informasi ikatan lokal, dan menampilkan dialog sistem yang memberi tahu pengguna tentang hilangnya ikatan dan mengarahkan mereka untuk menyambungkan kembali.