Android 16 platformu, uygulamanızı etkileyebilecek davranış değişiklikleri içerir.
Aşağıdaki davranış değişiklikleri, targetSdkVersion değerinden bağımsız olarak Android 16'da çalıştırılan tüm uygulamalar için geçerlidir. Uygulamanızı test etmeli ve uygun olduğu durumlarda bu değişiklikleri desteklemek için uygulamanızı gerektiği gibi değiştirmelisiniz.
Yalnızca Android 16'yı hedefleyen uygulamaları etkileyen davranış değişiklikleri listesini de incelemeyi unutmayın.
Temel işlevler
Android 16 (API düzeyi 36), Android sisteminin çeşitli temel özelliklerini değiştiren veya genişleten aşağıdaki değişiklikleri içerir.
JobScheduler kota optimizasyonları
Android 16'dan itibaren, normal ve hızlandırılmış iş yürütme çalışma zamanı kotasını aşağıdaki faktörlere göre ayarlıyoruz:
- Uygulamanın hangi uygulama bekleme modunda olduğu: Android 16'da etkin bekleme modu grupları, cömert bir çalışma zamanı kotasıyla zorunlu kılınmaya başlanacak.
- İş, uygulama üst durumda iken yürütülmeye başlarsa: Android 16'da, uygulama kullanıcıya görünürken başlatılan ve uygulama görünmez hale geldikten sonra devam eden işler, işin çalışma süresi kotasına uyar.
- İş, ön plan hizmeti çalıştırılırken yürütülüyorsa: Android 16'da, ön plan hizmetiyle eşzamanlı olarak yürütülen işler, iş çalışma süresi kotasına uyar. Kullanıcı tarafından başlatılan veri aktarımı için işlerden yararlanıyorsanız bunun yerine kullanıcı tarafından başlatılan veri aktarımı işlerini kullanmayı düşünebilirsiniz.
Bu değişiklik, WorkManager, JobScheduler ve DownloadManager kullanılarak planlanan görevleri etkiler. Bir işin neden durdurulduğunu belirlemek için WorkInfo.getStopReason() işlevini çağırarak işinizin neden durdurulduğunu günlüğe kaydetmenizi öneririz (JobScheduler işleri için JobParameters.getStopReason() işlevini çağırın).
Uygulamanızın durumunun kullanabileceği kaynakları nasıl etkilediği hakkında bilgi edinmek için Güç yönetimi kaynak sınırları başlıklı makaleyi inceleyin. Pil kullanımını optimize etmeye yönelik en iyi uygulamalar hakkında daha fazla bilgi için görev planlama API'leri için pil kullanımını optimize etme ile ilgili yönergelere bakın.
Ayrıca, bir işin neden yürütülmediğini anlamak için Android 16'da kullanıma sunulan yeni JobScheduler#getPendingJobReasonsHistory API'den yararlanmanızı öneririz.
Test
Uygulamanızın davranışını test etmek için, uygulama Android 16 cihazda çalıştığı sürece belirli iş kotası optimizasyonlarının geçersiz kılınmasını etkinleştirebilirsiniz.
"En üst durum, iş çalışma zamanı kotasına uyar" kuralının uygulanmasını devre dışı bırakmak için aşağıdaki adb komutunu çalıştırın:
adb shell am compat enable OVERRIDE_QUOTA_ENFORCEMENT_TO_TOP_STARTED_JOBS APP_PACKAGE_NAME
"Ön plan hizmetiyle eşzamanlı olarak yürütülen işler, iş çalışma süresi kotasına uyar" kuralının uygulanmasını devre dışı bırakmak için aşağıdaki adb komutunu çalıştırın:
adb shell am compat enable OVERRIDE_QUOTA_ENFORCEMENT_TO_FGS_JOBS APP_PACKAGE_NAME
Belirli uygulama bekleme modu grubu davranışlarını test etmek için aşağıdaki adb komutunu kullanarak uygulamanızın uygulama bekleme modu grubunu ayarlayabilirsiniz:
adb shell am set-standby-bucket APP_PACKAGE_NAME active|working_set|frequent|rare|restricted
Uygulamanızın bulunduğu uygulama bekleme grubunu anlamak için aşağıdaki adb komutunu kullanarak uygulamanızın uygulama bekleme grubunu alabilirsiniz:
adb shell am get-standby-bucket APP_PACKAGE_NAME
Boş bırakılan işlerin durdurulma nedeni
İşle ilişkili JobParameters nesnesi çöp toplandıysa ancak iş tamamlandığını belirtmek için JobService#jobFinished(JobParameters,
boolean) çağrılmadıysa iş terk edilmiş olur. Bu, işin uygulamanın bilgisi olmadan çalıştığını ve yeniden planlandığını gösterir.
JobScheduler'ı kullanan uygulamalar JobParameters nesnesine güçlü bir referans sağlamaz ve zaman aşımı artık STOP_REASON_TIMEOUT yerine yeni iş durdurma nedeni STOP_REASON_TIMEOUT_ABANDONED ile verilir.
Yeni terk edilmiş duraklatma nedeni sık sık gerçekleşirse sistem, iş sıklığını azaltmak için azaltma adımları atar.
Uygulamalar, terk edilmiş işleri tespit edip azaltmak için yeni durdurma nedenini kullanmalıdır.
WorkManager, AsyncTask veya DownloadManager kullanıyorsanız bu API'ler iş yaşam döngüsünü uygulamanız adına yönettiğinden bu değişiklikten etkilenmezsiniz.
JobInfo#setImportantWhileForeground tamamen kullanımdan kaldırılıyor
JobInfo.Builder#setImportantWhileForeground(boolean) yöntemi, planlama uygulaması ön plandayken veya geçici olarak arka plan kısıtlamalarından muafken bir işin önemini belirtir.
Bu yöntem, Android 12 (API düzeyi 31) sürümünden itibaren kullanımdan kaldırılmıştır. Android 16'dan itibaren bu yöntem artık etkili bir şekilde çalışmaz ve bu yöntem çağrılırsa yoksayılır.
Bu işlev kaldırma işlemi JobInfo#isImportantWhileForeground() için de geçerlidir. Android 16'dan itibaren, yöntem çağrılırsa false döndürülür.
Sıralı yayın önceliği kapsamı artık global değil
Android 应用可以为广播接收器定义优先级,以控制接收器接收和处理广播的顺序。对于清单声明的接收器,应用可以使用 android:priority 属性来定义优先级;对于上下文注册的接收器,应用可以使用 IntentFilter#setPriority() API 来定义优先级。发送广播时,系统会按接收器的优先级(从高到低)将其传送给接收器。
在 Android 16 中,无法保证使用 android:priority 属性或 IntentFilter#setPriority() 在不同进程中传送广播的顺序。广播优先级仅在同一应用进程内有效,而不会跨所有进程有效。
此外,广播优先级将自动限制在 (SYSTEM_LOW_PRIORITY + 1, SYSTEM_HIGH_PRIORITY - 1) 的范围内。只有系统组件才能将 SYSTEM_LOW_PRIORITY、SYSTEM_HIGH_PRIORITY 设置为广播优先级。
如果您的应用执行以下任一操作,可能会受到影响:
- 您的应用声明了具有相同广播 intent 的多个进程,并且希望根据优先级以特定顺序接收这些 intent。
- 您的应用进程与其他进程交互,并期望以特定顺序接收广播 intent。
如果进程需要相互协调,则应使用其他协调渠道进行通信。
ART ile ilgili dahili değişiklikler
Android 16, Android Runtime'da (ART) performansı artıran ve ek Java özellikleri için destek sağlayan en son güncellemeleri içerir. Google Play sistem güncellemeleri sayesinde bu iyileştirmeler, Android 12 (API düzeyi 31) ve sonraki sürümleri çalıştıran bir milyardan fazla cihazda da kullanılabilir.
Bu değişiklikler kullanıma sunulduğunda, ART'nin dahili yapılarına dayanan kitaplıklar ve uygulama kodları, Android 16 çalıştıran cihazların yanı sıra Google Play sistem güncellemeleri aracılığıyla ART modülünü güncelleyen önceki Android sürümlerinde düzgün çalışmayabilir.
Dahili yapılara (ör. SDK dışı arayüzler) güvenmek her zaman uyumluluk sorunlarına yol açabilir. Ancak ART değişiklikleri cihazın çalıştığı platform sürümüne bağlı olmadığı ve Google Play sistem güncellemeleri aracılığıyla bir milyardan fazla cihaza dağıtıldığı için özellikle dahili ART yapılarından yararlanan koda (veya kod içeren kitaplıklara) güvenmekten kaçınmak önemlidir.
Tüm geliştiriciler, uygulamalarını Android 16'da ayrıntılı bir şekilde test ederek uygulamalarının etkilenip etkilenmediğini kontrol etmelidir. Ayrıca, uygulamanızın dahili ART yapılarına dayalı olarak tespit ettiğimiz kitaplıklara bağımlı olup olmadığını görmek için bilinen sorunları kontrol edin. Etkilenen uygulama kodunuz veya kitaplık bağımlılıklarınız varsa mümkün olduğunda herkese açık API alternatifleri arayın ve sorun takipçimizde özellik isteği oluşturarak yeni kullanım alanları için herkese açık API'ler isteyin.
16 KB sayfa boyutu uyumluluk modu
Android 15, platformun performansını optimize etmek için 16 KB bellek sayfası desteğini kullanıma sundu. Android 16, 4 KB bellek sayfaları için geliştirilmiş bazı uygulamaların 16 KB bellek sayfaları için yapılandırılmış bir cihazda çalışmasına olanak tanıyan bir uyumluluk modu ekler.
Uygulamanız Android 16 veya sonraki bir sürümün yüklü olduğu bir cihazda çalışırken Android, uygulamanızda 4 KB'lık hizalanmış bellek sayfaları olduğunu algılarsa otomatik olarak uyumluluk modunu kullanır ve kullanıcıya bir bildirim iletişim kutusu gösterir. AndroidManifest.xml özelliğini AndroidManifest.xml içinde geriye dönük uyumluluk modunu etkinleştirecek şekilde ayarlamak, uygulamanız başlatıldığında iletişim kutusunun gösterilmesini engeller.android:pageSizeCompat android:pageSizeCompat mülkünü kullanmak için uygulamanızı Android 16 SDK'sını kullanarak derleyin.
En iyi performans, güvenilirlik ve kararlılık için uygulamanız 16 KB'ya hizalanmış olmalıdır. Uygulamalarınızı 16 KB bellek sayfalarını destekleyecek şekilde güncellemeyle ilgili daha fazla bilgi için son blog yayınımıza göz atın.
Kullanıcı deneyimi ve sistem arayüzü
Android 16 (API düzeyi 36), daha tutarlı ve sezgisel bir kullanıcı deneyimi oluşturmak için aşağıdaki değişiklikleri içerir.
Kullanımı engelleyen erişilebilirlik duyurularının desteğinin sonlandırılması
Android 16, announceForAccessibility kullanımı veya TYPE_ANNOUNCEMENT erişilebilirlik etkinliklerinin gönderilmesiyle karakterize edilen erişilebilirlik duyurularını desteklememektedir. Bu durum, TalkBack ve Android'in ekran okuyucusunun kullanıcıları için tutarsız kullanıcı deneyimleri oluşturabilir. Alternatifler ise Android'in çeşitli yardımcı teknolojileri genelinde daha geniş bir kullanıcı ihtiyacı yelpazesine daha iyi hizmet eder.
Alternatiflere örnekler:
- Pencere değişiklikleri gibi önemli kullanıcı arayüzü değişiklikleri için
Activity.setTitle(CharSequence)vesetAccessibilityPaneTitle(java.lang.CharSequence)değerlerini kullanın. Oluştur'daModifier.semantics { paneTitle = "paneTitle" }simgesini kullanarak - Kullanıcıyı kritik kullanıcı arayüzündeki değişiklikler hakkında bilgilendirmek için
setAccessibilityLiveRegion(int)simgesini kullanın. Oluştur'daModifier.semantics { liveRegion = LiveRegionMode.[Polite|Assertive]}simgesini kullanın . Bu bildirimler, bir görünüm her güncellendiğinde bildirim oluşturabileceğinden, dikkatli bir şekilde kullanılmalıdır. - Kullanıcıları hatalar hakkında bilgilendirmek için
AccessibilityEvent#CONTENT_CHANGE_TYPE_ERRORtüründeki birAccessibilityEventgönderin veAccessibilityNodeInfo#setError(CharSequence)değerini ayarlayın veyaTextView#setError(CharSequence)kullanın.
Kullanımdan kaldırılan announceForAccessibility API'nin referans dokümanlarında, önerilen alternatifler hakkında daha fazla bilgi verilmektedir.
3 düğmeli gezinme desteği
Android 16 为已正确迁移到预测性返回的应用的三按钮导航栏引入了预测性返回支持。长按返回按钮会启动预测性返回动画,让您预览返回滑动手势会打开的界面。
此行为适用于系统中支持预测性返回动画的所有区域,包括系统动画(返回主屏幕、跨任务和跨 activity)。
Otomatik temalı uygulama simgeleri
Android 16 QPR 2'den itibaren Android, tutarlı bir ana ekran deneyimi oluşturmak için uygulama simgelerine otomatik olarak temalar uygular. Bu durum, bir uygulama kendi temalı uygulama simgesini sağlamadığında ortaya çıkar. Uygulamalar, temalı uygulama simgelerinin tasarımını uyarlanabilir simgelerine tek renkli bir katman ekleyerek ve uygulama simgelerinin Android Studio'da nasıl görüneceğini önizleyerek kontrol edebilir.
Cihaz form faktörleri
Android 16 (API düzeyi 36), sanal cihaz sahipleri tarafından ekranlara yansıtılan uygulamalar için aşağıdaki değişiklikleri içerir.
Sanal cihaz sahibinin geçersiz kılmaları
Sanal cihaz sahibi, sanal cihaz oluşturan ve yöneten güvenilir veya ayrıcalıklı bir uygulamadır. Sanal cihaz sahipleri, uygulamaları sanal cihazda çalıştırıp kişisel bilgisayar, sanal gerçeklik cihazı veya araba bilgi-eğlence sistemi gibi uzak bir cihazın ekranına yansıtır. Sanal cihaz sahibi, cep telefonu gibi yerel bir cihazdadır.
Uygulama bazında geçersiz kılmalar
Android 16 (API düzeyi 36) çalıştıran cihazlarda sanal cihaz sahipleri, sanal cihaz sahiplerinin yönettiği belirli sanal cihazlardaki uygulama ayarlarını geçersiz kılabilir. Örneğin, uygulama düzenini iyileştirmek için sanal cihaz sahibi, uygulamaları harici bir ekrana yansıtırken yön, en-boy oranı ve yeniden boyutlandırma kısıtlamalarını yoksayabilir.
Sık karşılaşılan zarar veren değişiklikler
Android 16'daki bu davranış, özellikle dikey yönde küçük ekranlar için tasarlanmış düzenlerde, uygulamanızın araba ekranları veya Chromebook'lar gibi büyük ekranlı form faktörlerindeki kullanıcı arayüzünü etkileyebilir. Uygulamanızı tüm cihaz form faktörlerine uyarlanabilir hale getirme hakkında bilgi edinmek için Uyarlanabilir düzenler hakkında başlıklı makaleyi inceleyin.
Referanslar
Güvenlik
Android 16 (API düzeyi 36), uygulamaları ve kullanıcıları kötü amaçlı uygulamalardan korumak için sistem güvenliğini artıran değişiklikler içerir.
Niyet yönlendirme saldırılarına karşı gelişmiş güvenlik
Android 16, genel Intent yönlendirme saldırılarına
karşı varsayılan güvenlik sağlar. Minimum uyumluluk ve geliştirici değişiklikleri gerektirir.
Intent
Yönlendirme saldırılarına karşı varsayılan olarak güvenlik sağlamlaştırma çözümleri sunuyoruz. Çoğu durumda, amaçları kullanan uygulamalarda normalde uyumluluk sorunları yaşanmaz. Hangi uygulamalarda sorun yaşanabileceğini izlemek için geliştirme sürecimiz boyunca metrikler topladık.
Android'de Intent yönlendirmesi, saldırganın savunmasız bir uygulama bağlamında yeni bir bileşeni başlatmak için kullanılan bir Intent'in içeriğini kısmen veya tamamen kontrol edebildiği, kurban uygulamanın ise bir ("üst düzey") Intent'in ekstralar alanında güvenilmeyen bir alt düzey Intent başlattığı durumlarda gerçekleşir. Bu durum, saldırgan uygulamanın kurban uygulaması bağlamında özel bileşenler başlatmasına, ayrıcalıklı işlemleri tetiklemesine veya hassas verilere URI erişimi kazanmasına yol açabilir. Bu da veri hırsızlığına ve rastgele kod yürütmeye neden olabilir.
Intent yönlendirme işleme özelliğini devre dışı bırakma
Android 16, uygulamaların başlatma güvenlik korumalarını devre dışı bırakmasına olanak tanıyan yeni bir API sunuyor. Bu, varsayılan güvenlik davranışının meşru uygulama kullanım alanlarını engellediği belirli durumlarda gerekli olabilir.
Android 16 (API düzeyi 36) SDK'sı veya sonraki sürümlerine karşı derlenen uygulamalar için
Intent nesnesinde doğrudan removeLaunchSecurityProtection() yöntemini kullanabilirsiniz.
val i = intent
val iSublevel: Intent? = i.getParcelableExtra("sub_intent")
iSublevel?.removeLaunchSecurityProtection() // Opt out from hardening
iSublevel?.let { startActivity(it) }
Android 15 (API düzeyi 35) veya önceki sürümlere göre derlenen uygulamalar için
Önerilmese de removeLaunchSecurityProtection() yöntemine erişmek için yansıtma kullanabilirsiniz.
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) }
Tamamlayıcı uygulamalar artık keşif zaman aşımları hakkında bildirim almayacak
Android 16, kullanıcının konum gizliliğini kötü amaçlı uygulamalardan korumak için yardımcı cihaz eşleme akışında yeni bir davranış sunar. Android 16'da çalışan tüm tamamlayıcı uygulamalar artık RESULT_DISCOVERY_TIMEOUT kullanılarak keşif zaman aşımı hakkında doğrudan bilgilendirilmez. Bunun yerine, kullanıcıya görsel bir iletişim kutusu gösterilerek zaman aşımı etkinlikleri bildirilir. Kullanıcı iletişim kutusunu kapattığında uygulama, RESULT_USER_REJECTED ile ilişkilendirme hatası konusunda uyarılır.
Arama süresi de orijinal 20 saniyeden uzatıldı ve cihaz bulma işlemi, arama sırasında kullanıcı tarafından herhangi bir noktada durdurulabilir. Aramanın başlatılmasından sonraki ilk 20 saniye içinde en az bir cihaz bulunursa CDM başka cihaz aramayı durdurur.
Bağlantı
Android 16 (API düzeyi 36), çevre birimi cihazlarla bağlantıyı iyileştirmek için Bluetooth yığınında aşağıdaki değişiklikleri içerir.
Geliştirilmiş tahvil kaybı işleme
从 Android 16 开始,蓝牙堆栈已更新,以便在检测到远程配对丢失时提高安全性和用户体验。以前,系统会自动解除配对并启动新的配对流程,这可能会导致意外重新配对。在许多情况下,我们发现应用未以一致的方式处理债券损失事件。
为了统一体验,Android 16 改进了系统的绑定丢失处理。如果之前配对的蓝牙设备在重新连接时无法进行身份验证,系统会断开关联,保留本地配对信息,并显示系统对话框,告知用户配对已断开并指示他们重新配对。