تغییرات رفتار: همه برنامه ها

پلتفرم Android 14 شامل تغییرات رفتاری است که ممکن است بر برنامه شما تأثیر بگذارد. تغییرات رفتاری زیر برای همه برنامه‌ها هنگام اجرا بر روی Android 14 اعمال می‌شود، صرف‌نظر از targetSdkVersion . شما باید برنامه خود را آزمایش کنید و سپس آن را در صورت لزوم تغییر دهید تا در صورت لزوم از این موارد به درستی پشتیبانی شود.

مطمئن شوید که فهرستی از تغییرات رفتاری را که فقط بر برنامه‌هایی که Android 14 را هدف قرار می‌دهند تأثیر می‌گذارد، مرور کنید.

عملکرد اصلی

زمان‌بندی هشدار دقیق به‌طور پیش‌فرض رد می‌شود

精确的闹钟适用于用户指定的通知,或是在确切时间需要执行的操作。从 Android 14 开始,系统不再向以 Android 13 及更高版本为目标平台的大多数新安装应用预先授予 SCHEDULE_EXACT_ALARM 权限,该权限默认处于拒绝状态。

详细了解安排精确闹钟的权限变化

زمانی که برنامه‌ها در حافظه پنهان هستند، پخش‌های ثبت‌شده در زمینه در صف قرار می‌گیرند

在 Android 14 中,当应用处于缓存状态时,系统可以将上下文注册的广播放入队列中。这与 Android 12(API 级别 31)为异步 binder 事务引入的队列行为类似。在清单中声明的广播不会加入队列,并且应用会从缓存状态中移除以进行广播传递。

当应用离开缓存状态(例如返回前台)时,系统会传递所有已加入队列的广播。某些广播的多个实例 可能会合并为一个广播。取决于其他因素,如系统 运行状况,则可能会从缓存状态中移除应用,以及之前排队 广播。

برنامه ها فقط می توانند فرآیندهای پس زمینه خود را از بین ببرند

با شروع اندروید 14، زمانی که برنامه شما killBackgroundProcesses() را فراخوانی می‌کند، API می‌تواند فقط فرآیندهای پس‌زمینه برنامه شما را از بین ببرد.

اگر نام بسته برنامه دیگری را وارد کنید، این روش هیچ تاثیری بر فرآیندهای پس‌زمینه آن برنامه ندارد و پیام زیر در Logcat ظاهر می‌شود:

Invalid packageName: com.example.anotherapp

برنامه شما نباید از killBackgroundProcesses() API استفاده کند یا سعی کند بر چرخه عمر فرآیند سایر برنامه‌ها، حتی در نسخه‌های قدیمی‌تر سیستم عامل تأثیر بگذارد. اندروید به گونه‌ای طراحی شده است که برنامه‌های کش را در پس‌زمینه نگه می‌دارد و زمانی که سیستم به حافظه نیاز دارد، آنها را به‌طور خودکار از بین می‌برد. اگر برنامه شما برنامه‌های دیگر را به‌طور غیرضروری از بین می‌برد، می‌تواند عملکرد سیستم را کاهش دهد و مصرف باتری را با نیاز به راه‌اندازی مجدد کامل آن برنامه‌ها بعداً افزایش دهد، که به طور قابل‌توجهی نسبت به از سرگیری یک برنامه حافظه پنهان موجود، منابع بیشتری را مصرف می‌کند.

MTU برای اولین مشتری GATT که درخواست MTU می کند روی 517 تنظیم شده است

从 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

دلیل جدیدی که می توان یک برنامه را در سطل آماده به کار محدود قرار داد

Android 14 引入了将应用放入“受限待机”分桶的新原因。由于 onStartJobonStopJobonBind 方法超时,应用的作业会多次触发 ANR 错误。(如需了解对 onStartJobonStopJob 的更改,请参阅 JobScheduler 增强回调和网络行为。)

如需跟踪应用是否已进入“受限待机”分桶,我们建议您在作业执行时使用 API UsageStatsManager.getAppStandbyBucket() 进行日志记录,或者在应用启动时使用 UsageStatsManager.queryEventsForSelf() 进行日志记录。

mlock محدود به 64 کیلوبایت

在 Android 14(API 级别 34)及更高版本中,平台将可使用 mlock() 锁定的最大内存减少为每个进程 64 KB。在以前的版本中,每个进程的大小上限为 64 MB。此限制可促进跨应用和系统更好地管理内存。为了提高各设备之间的一致性,Android 14 针对兼容设备上的新 mlock() 限制添加了新的 CTS 测试

سیستم استفاده از منابع برنامه ذخیره شده را اعمال می کند

从设计上讲,当应用的进程移至后台且没有任何其他应用进程组件在运行时,应用进程将处于缓存状态。此类应用进程可能会因系统内存压力而终止。在此状态下,Activity 实例在调用并返回 onStop() 方法后执行的任何工作均不可靠,强烈建议不要这样做。

Android 14 对此设计引入了一致性和强制执行要求。在应用进程进入缓存状态后不久,系统会禁止后台工作,直到进程组件重新进入生命周期的活跃状态。

使用框架支持的典型生命周期 API(例如服务JobSchedulerJetpack WorkManager)的应用应该不受这些变化的影响。

تجربه کاربری

تغییراتی در نحوه تجربه کاربران از اعلان‌های غیرقابل رد کردن

اگر برنامه شما اعلان‌های پیش‌زمینه غیرقابل رد کردن را به کاربران نشان می‌دهد، Android 14 رفتار را تغییر داده است تا به کاربران اجازه دهد چنین اعلان‌هایی را رد کنند.

این تغییر برای برنامه‌هایی اعمال می‌شود که با تنظیم Notification.FLAG_ONGOING_EVENT از طریق Notification.Builder#setOngoing(true) یا NotificationCompat.Builder#setOngoing(true) از رد اعلان‌های پیش‌زمینه توسط کاربران جلوگیری می‌کنند. رفتار FLAG_ONGOING_EVENT تغییر کرده است تا این اعلان‌ها در واقع توسط کاربر قابل رد شود.

این نوع اعلان‌ها در شرایط زیر همچنان غیرقابل رد کردن هستند:

  • وقتی گوشی قفل است
  • اگر کاربر یک اقدام پاک کردن همه اعلان ها را انتخاب کند (که به اخراج های تصادفی کمک می کند)

همچنین، این رفتار جدید برای اعلان‌ها در موارد استفاده زیر اعمال نمی‌شود:

  • اعلان‌های CallStyle
  • کنترل کننده سیاست دستگاه (DPC) و بسته های پشتیبانی برای سازمانی
  • اطلاعیه های رسانه ای
  • بسته انتخابگر جستجوی پیش فرض

اطلاعات ایمنی داده ها بیشتر قابل مشاهده است

为了加强用户隐私保护,Android 14 增加了系统显示您在 Play 管理中心表单中声明的信息的位置数量。目前,用户可以在 Google Play 中的应用详情的数据安全部分查看此信息。

我们建议您查看应用的位置数据分享政策,并花一点时间对应用的 Google Play“数据安全”部分进行任何适用的更新。

如需了解详情,请参阅有关如何在 Android 14 上以更显眼的方式显示数据安全信息的指南。

دسترسی

مقیاس بندی فونت غیر خطی تا 200٪

从 Android 14 开始,系统支持字体放大高达 200%,为弱视用户提供了符合网络内容无障碍指南 (WCAG) 的其他无障碍功能选项。

如果您已使用放大像素 (sp) 单位来定义文本大小,这项更改可能不会对您的应用产生太大影响。不过,您应在启用最大字号 (200%) 的情况下执行界面测试,确保应用能够在不影响易用性的情况下适应较大的字号。

امنیت

حداقل سطح API هدف قابل نصب

با شروع اندروید 14، برنامه هایی با targetSdkVersion کمتر از 23 قابل نصب نیستند. الزام برنامه‌ها برای برآورده کردن حداقل الزامات سطح API هدف، امنیت و حریم خصوصی کاربران را بهبود می‌بخشد.

بدافزار اغلب سطوح API قدیمی‌تر را هدف قرار می‌دهد تا از حفاظت‌های امنیتی و حریم خصوصی که در نسخه‌های اندروید جدیدتر معرفی شده‌اند دور بزند. برای مثال، برخی از برنامه‌های بدافزار از targetSdkVersion 22 استفاده می‌کنند تا در معرض مدل مجوز زمان اجرا قرار نگیرند که در سال 2015 توسط Android 6.0 Marshmallow (سطح API 23) معرفی شد. این تغییر اندروید 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

نام بسته های مالک رسانه ممکن است ویرایش شود

فروشگاه رسانه از پرسش‌هایی برای ستون OWNER_PACKAGE_NAME پشتیبانی می‌کند، که نشان‌دهنده برنامه‌ای است که یک فایل رسانه خاص را ذخیره کرده است . با شروع در Android 14، این مقدار تغییر می کند مگر اینکه حداقل یکی از شرایط زیر صادق باشد:

  • برنامه ای که فایل رسانه ای را ذخیره می کند دارای یک نام بسته است که همیشه برای سایر برنامه ها قابل مشاهده است.
  • برنامه ای که از فروشگاه رسانه درخواست می کند مجوز QUERY_ALL_PACKAGES درخواست می کند.

درباره اینکه چگونه Android قابلیت مشاهده بسته را برای اهداف حفظ حریم خصوصی فیلتر می کند ، بیشتر بیاموزید.