Platforma Android 14 zawiera zmiany zachowania, które mogą mieć wpływ na Twoją aplikację.
Poniższe zmiany zachowania dotyczą wszystkich aplikacji na Androidzie 14, niezależnie od tego, targetSdkVersion
. Należy przetestować aplikację, a w razie potrzeby zmodyfikować ją tak, aby spełniała te wymagania.
Zapoznaj się też z listą zmian zachowania, które mają wpływ tylko na aplikacje kierowane na Androida 14.
Główna funkcja
Planowanie alarmów precyzyjnych jest domyślnie zablokowane
Alarmy precyzyjne są przeznaczone do powiadomień, które użytkownik chce otrzymać, lub do działań, które muszą być wykonane w określonym czasie. Od Androida 14 uprawnienia SCHEDULE_EXACT_ALARM
nie są wstępnie przyznawane większości nowo instalowanych aplikacji kierowanych na Androida 13 i nowsze wersje – domyślnie są one odrzucane.
Dowiedz się więcej o zmianach w uprawnieniach dotyczących planowania dokładnych alarmów.
Transmisje zarejestrowane w kontekście są umieszczane w kolejce, gdy aplikacje są umieszczane w pamięci podręcznej.
Na Androidzie 14 system może umieszczanie komunikatów zarejestrowanych kontekstowo w kolejce podczas korzystania przez aplikację z aplikacji jest w pamięci podręcznej. Jest to podobne do kolejkowania transakcji asynchronicznych w binderze, które zostało wprowadzone w Androidzie 12 (poziom API 31). Transmisje zadeklarowane w pliku manifestu nie są umieszczane w kolejce, a aplikacje są usuwane ze stanu pamięci podręcznej na potrzeby przesyłania komunikatów.
Gdy aplikacja opuści stan pamięci podręcznej, np. powrót na pierwszy plan, system dostarcza wszystkie transmisje w kolejce. Wiele wystąpień niektórych transmisji mogą zostać połączone w jedną transmisję. W zależności od innych czynników, takich jak system stanu, aplikacje mogą zostać usunięte ze stanu pamięci podręcznej, a wszystkie aplikacje znajdujące się w kolejce i wysyłanie wiadomości.
Aplikacje mogą zabijać tylko własne procesy w tle
Począwszy od Androida 14, gdy Twoja aplikacja wywołuje killBackgroundProcesses()
, interfejs API może zakończyć tylko procesy w tle Twojej aplikacji.
Jeśli podasz nazwę pakietu innej aplikacji, ta metoda nie będzie miała wpływu na procesy w tle tej aplikacji. W Logcat pojawi się wtedy taki komunikat:
Invalid packageName: com.example.anotherapp
Aplikacja nie powinna używać interfejsu API killBackgroundProcesses()
ani w inny sposób próbować
wpływa na cykl życia
innych aplikacji, nawet w starszych wersjach systemów operacyjnych.
Android został zaprojektowany tak, aby utrzymywał w tle aplikacje z pamięci podręcznej i zabijał je
automatycznie, gdy system potrzebuje pamięci. Jeśli aplikacja wyłącza inne aplikacje
może zmniejszyć wydajność systemu i zwiększyć zużycie baterii,
wymagając
późniejszego pełnego ponownego uruchomienia, co zajmuje znacznie
niż wznowienie istniejącej aplikacji w pamięci podręcznej.
MTU jest ustawione na 517 dla pierwszego klienta GATT, który prosi o MTU.
Począwszy od Androida 14 stos Bluetooth w tym systemie operacyjnym ściślej przestrzega specyfikacji Bluetooth Core w wersji 5.2 i ustawia MTU BLE ATT na 517 bajtów, gdy pierwszy klient GATT żąda MTU za pomocą interfejsu API BluetoothGatt#requestMtu(int)
, oraz ignoruje wszystkie kolejne żądania MTU dotyczące tego połączenia ACL.
Aby uwzględnić tę zmianę i ulepszyć aplikację, rozważ te opcje:
- Urządzenie peryferyjne powinno odpowiadać na żądanie MTU urządzenia z Androidem odpowiednią wartością, która może być obsługiwana przez urządzenie peryferyjne. Ostateczna wynegocjowana wartość będzie stanowić minimum wartości żądanej przez Androida i wartości podawanej przez urządzenie zdalne (np.
min(517, remoteMtu)
).- Wdrożenie tej poprawki może wymagać aktualizacji oprogramowania urządzenia peryferyjnego.
- Możesz też ograniczyć zapisywanie właściwości GATT na podstawie minimalnej wartości obsługiwanej przez Twoje urządzenie peryferyjne i otrzymanej zmiany MTU.
- Przypomnienie, że należy zmniejszyć o 5 bajtów obsługiwany rozmiar nagłówków
- Na przykład:
arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5
Nowy powód umieszczenia aplikacji w grupie ograniczonego trybu gotowości
Android 14 引入了一种可将应用放入受限待机模式存储分区的新原因。由于 onStartJob
、onStopJob
或 onBind
方法超时,应用的作业多次触发 ANR 错误。(如需了解对 onStartJob
和 onStopJob
的更改,请参阅 JobScheduler 强化了回调和网络行为。)
如需跟踪应用是否已进入受限待机分桶,我们建议您在作业执行时使用 API UsageStatsManager.getAppStandbyBucket()
进行日志记录,或在应用启动时使用 UsageStatsManager.queryEventsForSelf()
进行日志记录。
mlock ograniczony do 64 KB
在 Android 14(API 级别 34)及更高版本中,平台将可使用 mlock()
锁定的最大内存量减少到每个进程 64 KB。在之前的版本中,每个进程的上限为 64 MB。此限制有助于更好地管理应用和系统的内存。为了在各种设备上提供更一致的体验,Android 14 针对兼容设备上的新 mlock()
限制添加了一项新的 CTS 测试。
System wymusza wykorzystanie zasobów aplikacji z pamięci podręcznej
从设计上讲,当应用的进程移至后台且没有任何其他应用进程组件在运行时,应用进程将处于缓存状态。此类应用进程可能会因系统内存压力而终止。在此状态下,Activity
实例在调用并返回 onStop()
方法后执行的任何工作均不可靠,强烈建议不要这样做。
Android 14 对此设计引入了一致性和强制执行要求。在应用进程进入缓存状态后不久,系统会禁止后台工作,直到进程组件重新进入生命周期的活跃状态。
使用框架支持的典型生命周期 API(例如服务、JobScheduler
和 Jetpack WorkManager)的应用应该不受这些变化的影响。
Interfejs użytkownika
Zmiany w sposobie wyświetlania użytkownikom powiadomień, których nie można zamknąć
Jeśli Twoja aplikacja wyświetla użytkownikom powiadomienia na pierwszym planie, których nie można zamknąć, Android 14 Zmieniliśmy sposób działania, aby umożliwić użytkownikom odrzucanie takich powiadomień.
Ta zmiana dotyczy aplikacji, które uniemożliwiają użytkownikom odrzucanie powiadomień na pierwszym planie przez ustawienie Notification.FLAG_ONGOING_EVENT
w Notification.Builder#setOngoing(true)
lub NotificationCompat.Builder#setOngoing(true)
. Działanie funkcji
Aplikacja FLAG_ONGOING_EVENT
zmieniła ustawienie, aby takie powiadomienia były
które użytkownik może odrzucić.
Tego rodzaju powiadomień nadal nie można odrzucić w przypadku: warunki:
- Gdy telefon jest zablokowany
- Jeśli użytkownik wybierze działanie powiadomienia Wyczyść wszystko (co ułatwia przypadkowe odrzucenia)
Nowe zachowanie nie dotyczy też powiadomień w tych przypadkach użycia:
CallStyle
powiadomień- Kontroler zasad dotyczących urządzeń (DPC) i obsługujące pakiety dla firm
- Powiadomienia o multimediach
- Domyślny pakiet selektora wyszukiwania
Informacje o bezpieczeństwie danych są bardziej widoczne
为了加强用户隐私保护,Android 14 增加了系统显示您在 Play 管理中心表单中声明的信息的位置数量。目前,用户可以在 Google Play 中的应用详情的数据安全部分查看此信息。
我们建议您查看应用的位置数据分享政策,并花一点时间对应用的 Google Play“数据安全”部分进行任何适用的更新。
如需了解详情,请参阅有关如何在 Android 14 上以更显眼的方式显示数据安全信息的指南。
Ułatwienia dostępu
nieliniowe skalowanie czcionki do 200%,
Od Androida 14 system obsługuje skalowanie czcionek do 200%, zapewniając użytkownikom ze słabym wzrokiem dodatkowe opcje ułatwień dostępu zgodne z wytycznymi Web Content Accessibility Guidelines (WCAG).
Jeśli do definiowania rozmiaru tekstu używasz już skalowanych pikseli (sp), ta zmiana prawdopodobnie nie będzie miała dużego wpływu na Twoją aplikację. Powinieneś jednak przeprowadzić testy interfejsu z włączonym maksymalnym rozmiarem czcionki (200%), aby mieć pewność, że aplikacja obsługuje większe rozmiary czcionki bez wpływu na użyteczność.
Bezpieczeństwo
Minimalny instalowalny docelowy poziom interfejsu API
从 Android 14 开始,targetSdkVersion
低于 23 的应用无法安装。要求应用满足这些最低目标 API 级别要求有助于提高用户的安全性和隐私性。
恶意软件通常会以较旧的 API 级别为目标平台,以绕过在较新版本 Android 中引入的安全和隐私保护机制。例如,有些恶意软件应用使用 targetSdkVersion
22,以避免受到 Android 6.0 Marshmallow(API 级别 23)在 2015 年引入的运行时权限模型的约束。这项 Android 14 变更使恶意软件更难以规避安全和隐私权方面的改进限制。尝试安装以较低 API 级别为目标平台的应用将导致安装失败,并且 Logcat 中会显示以下消息:
INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 23, but found 7
在升级到 Android 14 的设备上,targetSdkVersion
低于 23 的所有应用都将继续保持安装状态。
如果您需要测试以旧版 API 级别为目标平台的应用,请使用以下 ADB 命令:
adb install --bypass-low-target-sdk-block FILENAME.apk
Nazwy pakietów właścicieli multimediów mogą zostać usunięte.
Magazyn multimediów obsługuje zapytania dotyczące kolumny OWNER_PACKAGE_NAME
, która wskazuje aplikację, w której został zapisany konkretny plik multimedialny. Począwszy od Androida 14 ta wartość jest zaciemniona, chyba że jest spełniony co najmniej 1 z tych warunków:
- Aplikacja, która przechowuje plik multimedialny, ma nazwę pakietu, która jest zawsze widoczna dla innych aplikacji.
Aplikacja, która wysyła zapytanie do magazynu multimediów, prosi o uprawnienia
QUERY_ALL_PACKAGES
.
Dowiedz się więcej o tym, jak Android filtruje widoczność pakietów ze względu na prywatność.