Android 14 platformunda, uygulamanızı etkileyebilecek davranış değişiklikleri vardır. Aşağıdaki davranış değişiklikleri, targetSdkVersion
bağımsız olarak Android 14'te çalıştırılan tüm uygulamalar için geçerlidir. Uygulamanızı test etmeniz ve geçerli olduğu durumlarda bunları düzgün şekilde desteklemek için gerektiği gibi değiştirmeniz gerekir.
Yalnızca Android 14'ü hedefleyen uygulamaları etkileyen davranış değişiklikleri listesini de incelemeyi unutmayın.
Temel işlevler
Tam alarm planlama varsayılan olarak reddedilir
Tam alarmlar, kullanıcıların bilinçli olarak yaptığı bildirimler veya belirli bir zamanda gerçekleşmesi gereken işlemler için kullanılır. Android 14'ten itibaren SCHEDULE_EXACT_ALARM
izni Android 13 ve sonraki sürümleri hedefleyen, yeni yüklenmiş uygulamaların çoğuna önceden verilmeyecektir. İzin varsayılan olarak reddedilir.
Tam alarmların planlanması izninde yapılan değişiklikler hakkında daha fazla bilgi edinin.
Uygulamalar önbelleğe alınırken bağlama kayıtlı yayınlar sıraya alınır
在 Android 14 中,当应用处于缓存状态时,系统可以将上下文注册的广播放入队列中。这与 Android 12(API 级别 31)为异步 binder 事务引入的队列行为类似。在清单中声明的广播不会加入队列,并且应用会从缓存状态中移除以进行广播传递。
当应用离开缓存状态(例如返回前台)时,系统会传递所有已加入队列的广播。某些广播的多个实例 可能会合并为一个广播。取决于其他因素,如系统 运行状况,则可能会从缓存状态中移除应用,以及之前排队 广播。
Uygulamalar yalnızca kendi arka plan işlemlerini sonlandırabilir
Android 14'ten itibaren uygulamanız killBackgroundProcesses()
çağırdığında,
API yalnızca kendi uygulamanızın arka plan işlemlerini sonlandırabilir.
Başka bir uygulamanın paket adını iletirseniz bu yöntemin arka planda işlem gerçekleştiriyor ve Logcat'te şu mesaj görünüyor:
Invalid packageName: com.example.anotherapp
Uygulamanız killBackgroundProcesses()
API'yi kullanmamalı veya
eski işletim sistemi sürümlerinde bile diğer uygulamaların
süreç yaşam döngüsünü etkilemelidir.
Android, önbelleğe alınan uygulamaları arka planda tutup kapatacak şekilde tasarlanmıştır.
otomatik olarak oluşturulur. Uygulamanız diğer uygulamaları kapatırsa
gereksiz şekilde sistem performansını düşürebilir ve pil tüketimini artırabilir
uygulamaların daha sonra tamamen yeniden başlatılmasını gerektirir. Bu da
bir uygulamayı devam ettirmekten daha iyidir.
MTU, MTU isteyen ilk GATT istemcisi için 517 olarak ayarlanır
从 Android 14 开始,Android 蓝牙堆栈会更严格地遵循蓝牙核心规范 5.2 版,当第一个 GATT 客户端使用 BluetoothGatt#requestMtu(int)
API 请求 MTU 时,会请求将 BLE ATT MTU 设置为 517 个字节,并忽略针对该 ACL 连接的所有后续 MTU 请求。
如需解决此变更并提高应用的稳健性,请考虑以下选项:
- 您的外围设备应使用可由外围设备适应的合理值来响应 Android 设备的 MTU 请求。最终商定的值将为 Android 请求的值和远程提供的值(例如
min(517, remoteMtu)
)中的最小值- 实现此修复可能需要更新外围设备的固件
- 或者,根据外围设备的已知受支持值与接收到的 MTU 变化之间的最小值限制 GATT 特征写入
- 温馨提示:您应该在支持的标头大小的基础上减少 5 个字节
- 例如:
arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5
Uygulamaların kısıtlanmış bekleme paketine yerleştirilmesinin yeni nedeni
Android 14, uygulamaların kısıtlı bekleme grubuna yerleştirilebilmesini sağlayan yeni bir neden sunar.
Uygulamanın işleri, onStartJob
, onStopJob
veya onBind
yöntemi zaman aşımları nedeniyle ANR hatalarını birden çok kez tetikler.
(onStartJob
ve onStopJob
ile ilgili değişiklikler için JobScheduler geri çağırmayı ve ağ davranışını güçlendirme konusuna bakın.)
Uygulamanın kısıtlanmış bekleme paketine girip girmediğini izlemek için iş yürütme sırasında API UsageStatsManager.getAppStandbyBucket()
veya uygulama başlatılırken UsageStatsManager.queryEventsForSelf()
ile giriş yapmanızı öneririz.
mlock 64 KB ile sınırlıdır
Platform, Android 14 (API düzeyi 34) ve sonraki sürümlerde mlock()
kullanılarak kilitlenebilen maksimum belleği işlem başına 64 KB'a düşürmektedir. Önceki sürümlerde sınır işlem başına 64 MB'tı. Bu kısıtlama, uygulamalar ve sistem genelinde bellek yönetimini iyileştirir. Android 14, cihazlar arasında daha fazla tutarlılık sağlamak amacıyla uyumlu cihazlarda yeni mlock()
sınırı için yeni bir CTS testi ekler.
Sistem, önbelleğe alınmış uygulama kaynaklarının kullanımını zorunlu kılar
从设计上讲,当应用的进程移至后台且没有任何其他应用进程组件在运行时,应用进程将处于缓存状态。此类应用进程可能会因系统内存压力而终止。在此状态下,Activity
实例在调用并返回 onStop()
方法后执行的任何工作均不可靠,强烈建议不要这样做。
Android 14 对此设计引入了一致性和强制执行要求。在应用进程进入缓存状态后不久,系统会禁止后台工作,直到进程组件重新进入生命周期的活跃状态。
使用框架支持的典型生命周期 API(例如服务、JobScheduler
和 Jetpack WorkManager)的应用应该不受这些变化的影响。
Kullanıcı deneyimi
Kullanıcıların kapatılamayan bildirimleri deneyimleme şekliyle ilgili değişiklikler
Uygulamanız kullanıcılara kapatılamayan ön plan bildirimleri gösteriyorsa Android 14 , kullanıcıların bu tür bildirimleri kapatmasına izin verecek şekilde davranışı değiştirdi.
Bu değişiklik, Notification.Builder#setOngoing(true)
veya NotificationCompat.Builder#setOngoing(true)
üzerinden Notification.FLAG_ONGOING_EVENT
ayarını yaparak kullanıcıların ön plan bildirimlerini kapatmasını engelleyen uygulamalar için geçerlidir. Kullanıcının davranışı
FLAG_ONGOING_EVENT
bu tür bildirimleri gerçekten alacak şekilde değişti
kullanıcı tarafından kapatılabilir.
Bu tür bildirimler aşağıdaki durumlarda kapatılamaz koşullar:
- Telefon kilitliyken
- Kullanıcı Tümünü temizle bildirim işlemini seçerse (Bu işlem, yanlışlıkla kapatma işlemleri)
Ayrıca bu yeni davranış, şu kullanım alanları vardır:
CallStyle
bildirimleri- Kurumsal cihaz politikası denetleyici (DPC) ve destekleyici paketler
- Medya bildirimleri
- Varsayılan Search Selector paketi
Veri güvenliği bilgileri daha görünür durumda
Android 14, kullanıcı gizliliğini iyileştirmek için Play Console formunda beyan ettiğiniz bilgilerin sistem tarafından gösterildiği yerlerin sayısını artırır. Şu anda kullanıcılar bu bilgileri uygulamanızın Google Play girişinde bulunan Veri Güvenliği bölümünden görüntüleyebilirler.
Uygulamanızın konum verisi paylaşım politikalarını incelemenizi ve uygulamanızın Google Play Veri Güvenliği bölümünde geçerli güncellemeleri yapmak için zaman ayırmanızı öneririz.
Android 14'te veri güvenliği bilgilerinin nasıl daha görünür olduğu ile ilgili kılavuzdan daha fazla bilgi edinebilirsiniz.
Erişilebilirlik
%200'e kadar doğrusal olmayan yazı tipi ölçeklendirme
从 Android 14 开始,系统支持字体放大高达 200%,为弱视用户提供了符合网络内容无障碍指南 (WCAG) 的其他无障碍功能选项。
如果您已使用放大像素 (sp) 单位来定义文本大小,这项更改可能不会对您的应用产生太大影响。不过,您应在启用最大字号 (200%) 的情况下执行界面测试,确保应用能够在不影响易用性的情况下适应较大的字号。
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ı çıkartılabilir
Medya mağazası, belirli bir medya dosyasını depolayan uygulamayı belirten OWNER_PACKAGE_NAME
sütunu için 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 istiyor.
Android'in gizlilik amacıyla paket görünürlüğünü nasıl filtrelediği hakkında daha fazla bilgi edinin.