يتضمّن نظام التشغيل Android 16 تغييرات في السلوك قد تؤثر في تطبيقك.
تنطبق تغييرات السلوك التالية على جميع التطبيقات عند تشغيلها على Android 16،
بغض النظر عن targetSdkVersion
. يجب اختبار تطبيقك ثم تعديله
حسب الحاجة لتتوافق مع هذه التغييرات، حيثما ينطبق ذلك.
احرص أيضًا على مراجعة قائمة التغييرات في السلوك التي تؤثر فقط في التطبيقات التي تستهدف الإصدار 16 من نظام التشغيل Android.
الوظيفة الأساسية
يتضمّن الإصدار 16 من Android التغييرات التالية التي تعدّل أو توسّع الإمكانات الأساسية المختلفة لنظام Android.
تحسينات الحصة في JobScheduler
اعتبارًا من الإصدار 16 من Android، سنعدّل حصة وقت تنفيذ المهام العادية والمهام المُسرَّعة استنادًا إلى العوامل التالية:
- مجموعة التطبيقات في وضع الاستعداد التي ينتمي إليها التطبيق: في الإصدار Android 16، سيبدأ فرض مجموعات التطبيقات النشطة في وضع الاستعداد من خلال حصة سخية لوقت التشغيل.
- إذا بدأت المهمة التنفيذ عندما يكون التطبيق في حالة "أهم التطبيقات": في الإصدار 16 من نظام التشغيل Android، ستلتزم المهام التي بدأت عندما كان التطبيق مرئيًا للمستخدم واستمرت بعد أن أصبح التطبيق غير مرئي بحصة وقت تشغيل المهمة.
- إذا كانت المهمة قيد التنفيذ أثناء تشغيل خدمة تعمل في المقدّمة: في الإصدار 16 من Android، ستلتزم المهام التي يتم تنفيذها بشكل متزامن مع خدمة تعمل في المقدّمة بالحصة المخصّصة لوقت تشغيل المهمة. إذا كنت تستخدِم المهام لنقل البيانات التي بدأها مستخدم، ننصحك باستخدام مهام نقل البيانات التي بدأها مستخدم بدلاً من ذلك.
يؤثّر هذا التغيير في المهام المُجدوَلة باستخدام WorkManager وJobScheduler و
DownloadManager. لتصحيح أخطاء سبب إيقاف إحدى المهام، ننصحك بتسجيل سبب إيقاف
مهمتك من خلال الاتصال WorkInfo.getStopReason()
(بالنسبة إلى
مهام JobScheduler، اتصل JobParameters.getStopReason()
).
لمزيد من المعلومات حول أفضل الممارسات لتحسين استهلاك البطارية، يُرجى الرجوع إلى الإرشادات حول تحسين استخدام البطارية لواجهات برمجة التطبيقات الخاصة بجدولة المهام.
ننصحك أيضًا بالاستفادة من واجهة برمجة التطبيقات الجديدة
JobScheduler#getPendingJobReasonsHistory
التي تم طرحها في
Android 16 لمعرفة سبب عدم تنفيذ إحدى المهام.
الاختبار
لاختبار سلوك تطبيقك، يمكنك تفعيل إلغاء تحسينات quot;حصة المهام" معيّنة طالما أنّ التطبيق يعمل على جهاز Android 16.
لإيقاف فرض "ستلتزم الحالة العليا بحصة وقت تشغيل المهمة"، شغِّل الرمز التاليadb
:
adb shell am compat enable OVERRIDE_QUOTA_ENFORCEMENT_TO_TOP_STARTED_JOBS APP_PACKAGE_NAME
لإيقاف فرض "المهام التي يتم تنفيذها بشكل متزامن مع
خدمة تعمل في المقدّمة ستلتزم بحصة وقت تشغيل المهمة"، نفِّذ الأمر التالي
adb
:
adb shell am compat enable OVERRIDE_QUOTA_ENFORCEMENT_TO_FGS_JOBS APP_PACKAGE_NAME
لاختبار سلوك معيّن لحزمة التطبيقات في وضع الاستعداد، يمكنك ضبط حزمة التطبيقات في وضع الاستعداد
لتطبيقك باستخدام الأمر adb
التالي:
adb shell am set-standby-bucket APP_PACKAGE_NAME active|working_set|frequent|rare|restricted
لفهم حزمة التطبيق في وضع الاستعداد التي يندرج تطبيقك ضمنها، يمكنك الحصول على حزمة التطبيق في وضع الاستعداد
لتطبيقك باستخدام الأمر adb
التالي:
adb shell am get-standby-bucket APP_PACKAGE_NAME
سبب إيقاف المهام الفارغة المهجورة
تحدث المهمة المهجورة عندما يتم جمع المهملات من عنصر JobParameters
المرتبط بالمهمة
، ولكن لم يتم استدعاء JobService#jobFinished(JobParameters,
boolean)
للإشارة إلى اكتمال المهمة. يشير ذلك إلى أنّه
قد يكون المهام قيد التشغيل ويتم إعادة جدولتها بدون علم التطبيق.
لا تحافظ التطبيقات التي تعتمد على JobScheduler على إشارة قوية إلى ملف برمجي
JobParameters
، وسيتم الآن منح مهلة سبب إيقاف المهمة الجديد
STOP_REASON_TIMEOUT_ABANDONED
بدلاً من STOP_REASON_TIMEOUT
.
إذا تكرّر سبب الإيقاف الجديد، سيتّخذ النظام خطوات لتخفيف المشكلة من خلال تقليل تكرار المهام.
على التطبيقات استخدام سبب الإيقاف الجديد لرصد المهام المتوقفة عن العمل والحدّ منها.
إذا كنت تستخدم WorkManager أو AsyncTask أو DownloadManager، لن تتأثر بهذه التغييرات، لأنّ واجهات برمجة التطبيقات هذه تدير دورة حياة المهام نيابةً عن تطبيقك.
إيقاف الإصدار القديم من JobInfo#setImportantWhileForeground نهائيًا
تشير طريقة JobInfo.Builder#setImportantWhileForeground(boolean)
إلى أهمية إحدى المهام عندما يكون تطبيق تحديد الموعد في
المقدّمة أو عندما يتم إعفاؤه مؤقتًا من القيود المفروضة على التطبيقات التي تعمل في الخلفية.
تم إيقاف هذه الطريقة نهائيًا منذ الإصدار 12 من Android (المستوى 31 لواجهة برمجة التطبيقات). اعتبارًا من الإصدار Android 16، لم تعُد هذه الطريقة تعمل بفعالية، وسيتم تجاهل استدعاء هذه الطريقة.
تنطبق إزالة هذه الوظيفة أيضًا على
JobInfo#isImportantWhileForeground()
. بدءًا من الإصدار Android
16، إذا تم استدعاء الطريقة، ستُرجع الطريقة false
.
لم يعُد نطاق أولوية البث المجدوَل عالميًا.
يُسمح لتطبيقات Android بتحديد الأولويات في أجهزة استقبال البث للتحكّم في
الترتيب الذي تتلقّى به أجهزة الاستقبال البث وتعالجه. بالنسبة إلى تطبيقات معالجة الإشعارات المُعلَن عنها في البيان، يمكنها استخدام السمة
android:priority
لتحديد الأولوية، وبالنسبة إلى تطبيقات معالجة الإشعارات المسجَّلة في السياق، يمكنها استخدام واجهة برمجة التطبيقات
IntentFilter#setPriority()
لتحديد الأولوية. عند إرسال بث، يرسله النظام إلى المستلِمين حسب تصاعد
أولويتهم، من الأعلى إلى الأدنى.
في الإصدار Android 16، لن يتم ضمان ترتيب إرسال البث باستخدام سمة android:priority
أو IntentFilter#setPriority()
في عمليات مختلفة. سيتم الالتزام بأولويات البث فقط في عملية التقديم نفسها وليس في جميع العمليات.
بالإضافة إلى ذلك، سيتم تلقائيًا حصر أولويات البث في النطاق (SYSTEM_LOW_PRIORITY
+ 1،
SYSTEM_HIGH_PRIORITY
- 1). سيتم السماح فقط لمكونات النظام
بضبط SYSTEM_LOW_PRIORITY
وSYSTEM_HIGH_PRIORITY
كأولوية
البث.
قد يتأثر تطبيقك إذا كان ينفّذ أيًا مما يلي:
- أعلن تطبيقك عن عمليات متعدّدة باستخدام نية البث نفسها، ولديه توقّعات بشأن تلقّي هذه النوايا بترتيب معين استنادًا إلى الأولوية.
- تتفاعل عملية تقديم الطلب مع عمليات أخرى وتتوقّع تلقّي نية بثّ بترتيب معيّن.
إذا كانت العمليات بحاجة إلى التنسيق مع بعضها، يجب أن تتواصل باستخدام قنوات تنسيق أخرى.
التغييرات الداخلية في ART
يتضمّن Android 16 أحدث التحديثات لنظام التشغيل Android Runtime (ART) التي تحسِّن أداء Android Runtime (ART) وتوفّر دعمًا لمزيد من ميزات Java. من خلال تحديثات نظام Google Play، تصبح هذه التحسينات متوفرة أيضًا لـ أكثر من مليار جهاز يعمل بالإصدار 12 من نظام Android (المستوى 31 من واجهة برمجة التطبيقات) والإصدارات الأحدث.
عند طرح هذه التغييرات، قد لا تعمل المكتبات ورموز التطبيقات التي تعتمد على البنى الداخلية لـ ART بشكل صحيح على الأجهزة التي تعمل بالإصدار 16 من Android، بالإضافة إلى إصدارات Android الأقدم التي تعمل على تحديث وحدة ART من خلال تحديثات نظام Google Play.
يمكن أن يؤدي الاعتماد على البنى الداخلية (مثل واجهات غير حِزم تطوير البرامج (SDK)) دائمًا إلى مشاكل في التوافق، ولكن من المهم بشكل خاص تجنُّب الاعتماد على الرموز البرمجية (أو المكتبات التي تحتوي على رموز برمجية) التي تستفيد من بنى ART الداخلية، لأنّ تغييرات ART لا تكون مرتبطة بإصدار النظام الذي يعمل عليه الجهاز وتصل إلى أكثر من مليار جهاز من خلال تحديثات نظام Google Play.
على جميع المطوّرين التحقّق مما إذا كان تطبيقاتهم متأثرة من خلال اختبارها بدقة على Android 16. بالإضافة إلى ذلك، يمكنك الاطّلاع على المشاكل المعروفة لتحديد ما إذا كان تطبيقك يعتمد على أي مكتبات رصدناها تعتمد بدورها على بنى ART الداخلية. إذا كان لديك رموز برمجية للتطبيقات أو مكتبات متأثرة ، ابحث عن بدائل لواجهات برمجة التطبيقات المتاحة للجميع كلما أمكن ذلك واطلِب واجهات برمجة التطبيقات المتاحة للجميع لحالات الاستخدام الجديدة من خلال إنشاء طلب ميزة في أداة تتبُّع الصعوبات.
وضع التوافق مع حجم الصفحة البالغ 16 كيلوبايت
وفّر الإصدار 15 من Android إمكانية استخدام صفحات ذاكرة بحجم 16 كيلوبايت لتحسين أداء المنصة. يضيف الإصدار 16 من نظام التشغيل Android وضع ملف شخصي متوافقًا، ما يسمح بتشغيل بعض التطبيقات المُنشأة لصفحات ذاكرة بحجم 4 كيلوبايت على جهاز تم ضبطه لصفحات ذاكرة بحجم 16 كيلوبايت.
إذا رصد نظام التشغيل Android أنّ تطبيقك يتضمّن صفحات ذاكرة بحجم 4 كيلوبايت، فإنه
يستخدِم تلقائيًا وضع التوافق ويعرض مربع حوار إشعار
للمستخدم. سيؤدي ضبط سمة android:pageSizeCompat
في AndroidManifest.xml
لتفعيل وضع التوافق مع الإصدارات القديمة إلى منع عرض
المربّع الحواري عند تشغيل تطبيقك. لتحقيق أفضل أداء وموثوقية وثبات،
يجب أن يظل تطبيقك متوافقًا مع حجم الصفحة الذي يبلغ 16 كيلوبايت. يمكنك الاطّلاع على مزيد من التفاصيل في
مشاركة المدونة الأخيرة
التي نشرناها حول تحديث تطبيقاتك لتتوافق مع صفحات الذاكرة التي تبلغ سعة كل صفحة منها 16 كيلوبايت.
![](https://developer.android.com/static/about/versions/16/images/16-kb-compat-mode-dialog.png?authuser=3&hl=ar)
تجربة المستخدم وواجهة المستخدم للنظام
يتضمّن الإصدار 16 من Android التغييرات التالية التي تهدف إلى توفير تجربة استخدام أكثر اتساقًا وسهولة.
إيقاف إعلانات إمكانية الوصول المزعجة نهائيًا
يوقف نظام التشغيل Android 16 نهائيًا إعلانات تسهيل الاستخدام التي تتميز باستخدام
announceForAccessibility
أو إرسال
TYPE_ANNOUNCEMENT
أحداث تسهيل الاستخدام. ويمكن أن تؤدي هذه العناصر إلى اختلاف تجربتَي المستخدمين في TalkBack وقارئ شاشة Android،
وتعمل العناصر البديلة بشكل أفضل على تلبية مجموعة أوسع من احتياجات المستخدمين في مجموعة متنوعة من
التكنولوجيات المساعِدة في Android.
أمثلة على الحلول البديلة:
- بالنسبة إلى التغييرات المهمة في واجهة المستخدم، مثل التغييرات في النوافذ، استخدِم
Activity.setTitle(CharSequence)
وsetAccessibilityPaneTitle(java.lang.CharSequence)
. في الكتابة، استخدِمModifier.semantics { paneTitle = "paneTitle" }
- لإعلام المستخدم بالتغييرات في واجهة المستخدم المهمة، استخدِم رمز
setAccessibilityLiveRegion(int)
. في ميزة "إنشاء"، استخدِم رمزModifier.semantics { liveRegion = LiveRegionMode.[Polite|Assertive]}
. يجب استخدام هذه الإعدادات بقدر معقول، لأنّها قد تؤدي إلى إنشاء إشعارات في كل مرة يتم فيها تعديل أحد "المشاهدات". - لإعلام المستخدمين بالأخطاء، أرسِل
AccessibilityEvent
من النوعAccessibilityEvent#CONTENT_CHANGE_TYPE_ERROR
واضبطAccessibilityNodeInfo#setError(CharSequence)
، أو استخدِمTextView#setError(CharSequence)
.
تتضمّن المستندات المرجعية لواجهة برمجة التطبيقات
announceForAccessibility
المتوقّفة نهائيًا مزيدًا من التفاصيل حول
البدائل المقترَحة.
إتاحة وضع "التنقّل باستخدام ثلاثة أزرار"
يتيح نظام Android 16 ميزة "الرجوع التوقّعي" في ميزة التنقّل باستخدام 3 أزرار للتطبيقات التي تم نقلها بشكل صحيح إلى ميزة "الرجوع التوقّعي". يؤدي الضغط مع الاستمرار على زر الرجوع إلى تشغيل صورة متحركة تنبؤية للرجوع، ما يمنحك معاينة للصفحة التي يؤدي التمرير السريع للخلف إلى عرضها.
ينطبق هذا السلوك على جميع أقسام النظام التي تتيح استخدام الصور المتحركة التنبؤية للرجوع، بما في ذلك الصور المتحركة في النظام (للرجوع إلى الشاشة الرئيسية والتنقّل بين المهام وتنفيذ عدة أنشطة في الوقت نفسه).
أشكال الأجهزة
يتضمّن نظام التشغيل Android 16 التغييرات التالية على التطبيقات عند عرضها على الشاشات من قِبل مالكي الأجهزة الافتراضية.
عمليات إلغاء مالك الجهاز الافتراضي
مالك الجهاز الافتراضي هو تطبيق موثوق به أو مميّز ينشئ ويدير جهازًا افتراضيًا. يشغِّل مالكو الأجهزة الافتراضية التطبيقات على جهاز افتراضي ثم يُعرِضون التطبيقات على شاشة جهاز بعيد، مثل كمبيوتر شخصي أو جهاز واقع افتراضي أو نظام معلومات ترفيهية في السيارة. يكون مالك الجهاز الافتراضي على جهاز محلي، مثل هاتف جوّال.
![](https://developer.android.com/static/about/versions/16/images/16-virtual-device-owner-projection.png?authuser=3&hl=ar)
عمليات إلغاء الإعدادات لكل تطبيق
على الأجهزة التي تعمل بنظام التشغيل Android 16، يمكن لمالكي الأجهزة الافتراضية تجاوز إعدادات التطبيقات على أجهزة افتراضية محدّدة يديرها أصحاب الأجهزة الافتراضية. على سبيل المثال، لتحسين تنسيق التطبيق، يمكن لمالك الجهاز الافتراضي تجاهل القيود المفروضة على الاتجاه ونسبة العرض إلى الارتفاع وإمكانية تغيير الحجم عند بث التطبيقات على شاشة خارجية.
التغييرات الشائعة التي قد تؤدي إلى حدوث أعطال
قد يؤثر سلوك Android 16 في واجهة مستخدم تطبيقك على الشاشات الكبيرة، وذلك في ما يتعلّق بعوامل مثل شاشات السيارات أو أجهزة Chromebook، لا سيما التنسيقات التي تم تصميمها للشاشات الصغيرة في الوضع العمودي. للتعرّف على كيفية جعل تطبيقك متوافقًا مع جميع أشكال الأجهزة، اطّلِع على لمحة عن التنسيقات المتوافقة.
المراجع
الأمان
يتضمّن الإصدار 16 من Android تغييرات تعزّز أمان النظام بهدف المساعدة في حماية التطبيقات والمستخدمين من التطبيقات الضارّة.
أمان محسّن ضد هجمات إعادة التوجيه المستندة إلى الأهداف
يقدّم نظام التشغيل Android 16 أمانًا تلقائيًا ضد هجمات Intent
إعادة التوجيه العامة،
مع الحد الأدنى من التوافق والتغييرات المطلوبة من المطوّرين.
نحن بصدد تقديم حلول تحصين الأمان تلقائيًا Intent
لإعادة توجيه
الاختراقات. في معظم الحالات، لن تواجه التطبيقات التي تستخدم النوايا أيّ
مشاكل في التوافق، فقد جمعنا المقاييس طوال عملية التطوير
لرصد التطبيقات التي قد تواجه مشاكل.
تحدث إعادة توجيه Intent في Android عندما يتمكّن المهاجم من التحكّم جزئيًا أو كليًا في محتوى Intent المستخدَم لإطلاق مكوّن جديد في سياق تطبيق معرّض للاختراق، بينما يطلق التطبيق المستهدف Intent من المستوى الفرعي غير الموثوق فيه في حقل التطبيقات الإضافية ("Intent من المستوى الأعلى"). يمكن أن يؤدي ذلك إلى قيام تطبيق المهاجم بتشغيل مكوّنات خاصة في سياق التطبيق المستهدف، أو بدء إجراءات مميّزة، أو الحصول على إذن الوصول إلى عناوين URI للوصول إلى البيانات الحسّاسة، مما قد يؤدي بدوره إلى سرقة البيانات وتنفيذ رموز برمجية عشوائية.
إيقاف معالجة إعادة التوجيه المستندة إلى الأهداف
يقدّم نظام التشغيل Android 16 واجهة برمجة تطبيقات جديدة تتيح للتطبيقات إيقاف ميزات أمان الإطلاق. قد يكون ذلك ضروريًا في حالات معيّنة يتداخل فيها سلوك أمان الإعدادات التلقائية مع حالات الاستخدام المشروعة للتطبيق.
بالنسبة إلى التطبيقات التي تستهدف الإصدار 16 من نظام التشغيل Android أو الإصدارات الأحدث
يمكنك استخدام الطريقة removeLaunchSecurityProtection()
مباشرةً على عنصر Intent.
val i = intent
val iSublevel: Intent? = i.getParcelableExtra("sub_intent")
iSublevel?.removeLaunchSecurityProtection() // Opt out from hardening
iSublevel?.let { startActivity(it) }
التطبيقات التي تستهدف الإصدار 15 من Android (المستوى 35 لواجهة برمجة التطبيقات) أو الإصدارات الأقدم
على الرغم من أنّه لا يُنصح بذلك، يمكنك استخدام ميزة "العرض" للوصول إلى الطريقة
removeLaunchSecurityProtection()
.
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) }