Android 14 platformu, uygulamanızı etkileyebilecek davranış değişiklikleri içerir.
Aşağıdaki davranış değişiklikleri, Android 14'te çalıştırıldığında tüm uygulamalar için geçerlidir.
targetSdkVersion
. Uygulamanızı test etmeli ve uygun olduğu durumlarda bunları düzgün şekilde desteklemek için gerektiği gibi değiştirmelisiniz.
Yalnızca Android 14'ü hedefleyen uygulamaları etkileyen davranış değişiklikleri listesini de incelemeyi unutmayın.
Temel işlevler
Tam zamanlı alarm planlama isteği varsayılan olarak reddedilir
Exact alarms are meant for user-intentioned notifications, or for actions that
need to happen at a precise time. Starting in Android 14, the
SCHEDULE_EXACT_ALARM
permission is no longer being pre-granted to most newly installed apps
targeting Android 13 and higher—the permission is denied by default.
Learn more about the changes to the permission for scheduling exact alarms.
Bağlam kaydı yapılmış yayınlar, uygulamalar önbelleğe alınırken sıraya alınır.
Android 14'te sistem uygulama sırasında bağlama kayıtlı yayınları sıraya koyun önbelleğe alınmış durumda olmalıdır. Bu, sıraya eklemeye benzer Android 12'nin (API düzeyi 31) eşzamansız bağlayıcı için kullanıma sunduğu davranış işlemlerdir. Manifest olarak tanımlanan yayınlar sıraya alınmaz ve uygulamalar kaldırılır önbelleğe alınmış durumdan çıkarılacak.
Uygulama önbellek durumundan çıktığında (ör. ön plana geri dönme), sistemi sıraya alınmış yayınları teslim eder. Belirli yayınların birden çok örneği tek bir yayında birleştirilebilir. Sistem sağlığı gibi diğer faktörlere bağlı olarak uygulamalar önbelleğe alınmış durumdan kaldırılabilir ve daha önce sıraya alınmış yayınlar yayınlanır.
Uygulamalar yalnızca kendi arka plan işlemlerini sonlandırabilir
从 Android 14 开始,当您的应用调用 killBackgroundProcesses()
时,该 API 只能终止您自己应用的后台进程。
如果您传入另一个应用的软件包名称,此方法对该应用的后台进程没有影响,并且 Logcat 中会显示以下消息:
Invalid packageName: com.example.anotherapp
您的应用不应使用 killBackgroundProcesses()
API,也不得以其他方式尝试影响其他应用的进程生命周期,即使在旧版操作系统上也是如此。Android 旨在让缓存应用在后台运行,并在系统需要内存时自动终止它们。如果您的应用会不必要地终止其他应用,则由于之后需要完全重启这些应用,因此可能会降低系统性能并增加耗电量,这比恢复现有缓存应用所消耗的资源要多得多。
MTU, MTU isteyen ilk GATT istemcisi için 517 olarak ayarlanır.
Android 14'ten itibaren Android Bluetooth yığını, Bluetooth Core Specification'in 5.2 sürümüne daha sıkı bağlı kalır ve ilk GATT istemcisi BluetoothGatt#requestMtu(int)
API'yi kullanarak MTU istediğinde BLE ATT MTU'yu 517 bayt olarak ister ve bu ACL bağlantısında sonraki tüm MTU isteklerini yoksayar.
Bu değişikliği ele almak ve uygulamanızı daha güçlü hale getirmek için aşağıdaki seçenekleri değerlendirin:
- Çevresel cihazınız, Android cihazın MTU isteğine çevresel cihaz tarafından karşılanabilir makul bir değerle yanıt vermelidir. Pazarlık yapılan nihai değer, Android'in istediği değer ile uzaktan kumanda tarafından sağlanan değerin (ör.
min(517, remoteMtu)
) minimum değeri olacaktır.- Bu düzeltmenin uygulanması için çevre birimi donanım yazılımının güncellenmesi gerekebilir.
- Alternatif olarak, GATT özelliği yazma işlemlerinizi, çevre biriminizin bilinen desteklenen değeri ile alınan MTU değişikliği arasındaki minimum değere göre sınırlayın
- Üstbilgiler için desteklenen boyuttan 5 bayt çıkarmanız gerektiğini hatırlatmak isteriz
- Örneğin:
arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5
Bir uygulamanın kısıtlanmış bekleme grubuna yerleştirilebileceği yeni neden
Android 14, bir uygulamanın kısıtlanmış bekleme paketine yerleştirilmesinin yeni bir nedenini kullanıma sunar.
Uygulamanın işleri, onStartJob
, onStopJob
veya onBind
yöntem zaman aşımları nedeniyle birden çok kez ANR hatası tetikliyor.
(onStartJob
ve onStopJob
'teki değişiklikler için JobScheduler, geri çağırma ve ağ davranışını güçlendiriyor başlıklı makaleyi inceleyin.)
Uygulamanın kısıtlanmış bekleme grubuna girip girmediğini izlemek için iş yürütme sırasında API ile UsageStatsManager.getAppStandbyBucket()
veya uygulama başlatılırken UsageStatsManager.queryEventsForSelf()
günlük kaydını almanızı öneririz.
mlock 64 KB ile sınırlıdır
Android 14 (API düzeyi 34) ve sonraki sürümlerde platform, mlock()
kullanılarak kilitlenebilen maksimum bellek miktarını işlem başına 64 KB'ya düşürür. Önceki sürümlerde sınır işlem başına 64 MB idi. Bu kısıtlama, uygulamalar ve sistem genelinde daha iyi bellek yönetimi sağlar. Android 14, cihazlar arasında daha tutarlı bir deneyim sunmak için uyumlu cihazlardaki yeni mlock()
sınırı için yeni bir CTS testi ekler.
Sistem, önbelleğe alınmış uygulama kaynak kullanımını zorunlu kılar
Tasarıyla, bir uygulamanın işlemi arka plana taşındığında ve başka hiçbir uygulama işlemi bileşeni çalışmadığında önbelleğe alınmış durumdadır. Bu tür bir uygulama işlemi, sistem belleği baskısı nedeniyle sonlandırılabilir. onStop()
yöntemi çağrıldıktan ve döndürüldükten sonra Activity
örnekleri tarafından bu durumdayken gerçekleştirilen tüm işlemler güvenilir değildir ve kesinlikle önerilmez.
Android 14, bu tasarıma tutarlılık ve yaptırım getiriyor. Bir uygulama işlemi önbelleğe alınmış duruma girdikten kısa süre sonra, bir işlem bileşeni yaşam döngüsünün etkin durumuna yeniden girene kadar arka plan çalışmasına izin verilmez.
services, JobScheduler
ve Jetpack WorkManager gibi çerçeve tarafından desteklenen tipik yaşam döngüsü API'lerini kullanan uygulamalar bu değişikliklerden etkilenmeyecektir.
Kullanıcı deneyimi
Kullanıcıların kapatılamayan bildirimleri deneyimleme şeklindeki değişiklikler
如果您的应用向用户显示不可关闭的前台通知,请注意:Android 14 已更改此行为,允许用户关闭此类通知。
这项变更适用于阻止用户关闭前台的应用
将 Notification.FLAG_ONGOING_EVENT
设置为
Notification.Builder#setOngoing(true)
或
NotificationCompat.Builder#setOngoing(true)
。FLAG_ONGOING_EVENT
的行为已发生变化,使用户实际上能够关闭此类通知。
在以下情况下,此类通知仍不可关闭:
- 当手机处于锁定状态时
- 如果用户选择全部清除通知操作(有助于防止意外关闭)
此外,这一新行为不适用于以下用例中的通知:
CallStyle
条通知- 企业设备政策控制器 (DPC) 和支持软件包
- 媒体通知
- 默认的搜索选择器软件包
Veri güvenliği bilgileri daha görünür
Android 14, kullanıcı gizliliğini artırmak için sistemin Play Console formunda beyan ettiğiniz bilgileri gösterdiği yerlerin sayısını artırır. Şu anda kullanıcılar bu bilgileri uygulamanızın Google Play girişindeki Veri Güvenliği bölümünde görüntüleyebilir.
Uygulamanızın konum verisi paylaşım politikalarını incelemenizi ve uygulamanızın Google Play Veri Güvenliği bölümünde gerekli güncellemeleri yapmanızı öneririz.
Android 14'te veri güvenliği bilgilerinin daha görünür hale getirilmesi hakkında daha fazla bilgiyi kılavuzda bulabilirsiniz.
Erişilebilirlik
%200'e kadar doğrusal olmayan yazı tipi ölçeklendirme
Android 14'ten itibaren sistem, yazı tipini %200'e kadar ölçeklendirmeyi destekler. Bu sayede, az gören kullanıcılara Web İçerik Erişilebilirliği Kuralları (WCAG) ile uyumlu ek erişilebilirlik seçenekleri sunulur.
Metin boyutunu tanımlamak için zaten ölçeklendirilmiş piksel (sp) birimleri kullanıyorsanız bu değişikliğin uygulamanız üzerinde büyük bir etkisi olmayacaktır. Ancak uygulamanızın kullanılabilirliği etkilemeden daha büyük yazı tipi boyutlarını kullanabilmesini sağlamak için maksimum yazı tipi boyutu etkinken (%200) kullanıcı arayüzü testi yapmanız gerekir.
Güvenlik
Minimum yüklenebilir hedef API düzeyi
Android 14'ten itibaren
targetSdkVersion
23'ten düşük
yüklenemiyor. Uygulamaların bu minimum hedef API düzeyi şartlarını karşılamasını zorunlu tutmak, kullanıcıların güvenliğini ve gizliliğini artırır.
Kötü amaçlı yazılımlar, güvenlik ve gizliliği atlatmak için genellikle eski API düzeylerini hedefler
koruma özellikleri bulunuyor. Örneğin,
bazı kötü amaçlı yazılım uygulamalarıtargetSdkVersion
Android 6.0 Marshmallow (API) tarafından 2015'te kullanıma sunulan çalışma zamanı izin modeli
23. düzey). Android 14'teki bu değişiklik, kötü amaçlı yazılımların güvenlikten kaçınmasını zorlaştırıyor
ve gizlilikle ilgili iyileştirmeler yapıldı.
Daha düşük bir API düzeyini hedefleyen bir uygulama yüklemeye çalışırsanız
Logcat'te aşağıdaki mesajla birlikte yükleme hatası:
INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 23, but found 7
Android 14'e geçen cihazlarda, targetSdkVersion
daha düşük
23'ten fazla yüklü kalmaya devam eder.
Eski bir API düzeyini hedefleyen bir uygulamayı test etmeniz gerekirse aşağıdaki ADB'yi kullanın komut:
adb install --bypass-low-target-sdk-block FILENAME.apk
Medya sahibinin paket adları çıkarılabilir
Medya deposu, belirli bir medya dosyasını depolayan uygulamayı belirten OWNER_PACKAGE_NAME
sütunuyla ilgili sorguları destekler. Android 14'ten itibaren, aşağıdaki koşullardan en az biri doğru olmadığı sürece bu değer çıkartılır:
- Medya dosyasını depolayan uygulamanın, diğer uygulamalar tarafından her zaman görülebilen bir paket adı vardır.
Medya mağazasını sorgulayan uygulama,
QUERY_ALL_PACKAGES
iznini ister.
Android'in gizlilik amacıyla paket görünürlüğünü nasıl filtrelediği hakkında daha fazla bilgi edinin.