با شروع Android 9 (سطح API 28)، این پلتفرم رابطهای غیر SDK را محدود میکند که برنامه شما میتواند استفاده کند. این محدودیتها زمانی اعمال میشوند که برنامهای به یک رابط غیر SDK ارجاع میدهد یا سعی میکند با استفاده از بازتاب یا JNI، دسته آن را بدست آورد. این محدودیتها برای کمک به بهبود تجربه کاربر و توسعهدهنده و کاهش خطرات خرابی برای کاربران و عرضه اضطراری برای توسعهدهندگان اعمال شد. برای اطلاعات بیشتر درباره این تصمیم، به بهبود پایداری با کاهش استفاده از رابطهای غیر SDK مراجعه کنید.
بین رابط های SDK و غیر SDK تفاوت قائل شوید
به طور کلی، رابطهای SDK عمومی آنهایی هستند که در فهرست بستهبندی فریمورک Android مستند شدهاند. مدیریت رابطهای غیر SDK یک جزئیات پیادهسازی است که API آن را خلاصه میکند، بنابراین این رابطها بدون اطلاع قبلی ممکن است تغییر کنند.
برای جلوگیری از خرابی و رفتار غیرمنتظره، برنامهها فقط باید از بخشهای مستند شده رسمی کلاسها در SDK استفاده کنند. این همچنین به این معنی است که هنگام تعامل با کلاس با استفاده از مکانیسمهایی مانند بازتاب، نباید به روشها یا فیلدهایی که در SDK فهرست نشدهاند دسترسی داشته باشید.
لیست های غیر SDK API
با هر نسخه از Android، رابط های غیر SDK اضافی محدود می شوند. ما میدانیم که این محدودیتها میتوانند بر گردش کار انتشار شما تأثیر بگذارند، و میخواهیم مطمئن شویم که ابزارهایی برای تشخیص استفاده از رابطهای غیر SDK، فرصتی برای ارائه بازخورد و زمان برای برنامهریزی و تطبیق با خطمشیهای جدید در اختیار دارید.
برای به حداقل رساندن تأثیر محدودیتهای غیر SDK بر روی گردش کار توسعه شما، رابطهای غیر SDK به فهرستهایی تقسیم میشوند که بسته به اینکه کدام سطح API مورد هدف قرار میگیرد، مشخص میکند که چقدر استفاده از آنها محدود است. جدول زیر هر یک از این لیست ها را شرح می دهد:
فهرست کنید | برچسب های کد | توضیحات |
---|---|---|
لیست بلاک شده |
| رابطهای غیر SDK که نمیتوانید بدون در نظر گرفتن سطح API هدف برنامهتان از آنها استفاده کنید. اگر برنامه شما سعی کند به یکی از این رابطها دسترسی پیدا کند، سیستم با خطا مواجه میشود . |
مشروط مسدود شده است |
| با شروع Android 9 (سطح API 28)، هر سطح API دارای رابط های غیر SDK است که زمانی که یک برنامه آن سطح API را هدف قرار می دهد، محدود می شود. این لیستها با حداکثر سطح API ( اگر برنامه شما سعی کند به رابطی دسترسی پیدا کند که برای سطح API هدف شما محدود شده است، سیستم طوری رفتار می کند که گویی API بخشی از فهرست مسدود شده است . |
پشتیبانی نمی شود |
| رابط های غیر SDK که نامحدود هستند و برنامه شما می تواند از آنها استفاده کند. البته توجه داشته باشید که این رابطها پشتیبانی نمیشوند و بدون اطلاع قبلی ممکن است تغییر کنند. انتظار می رود این رابط ها به صورت مشروط در نسخه های اندروید آینده در لیست max-target-x مسدود شوند. |
SDK |
| رابطهایی که میتوان آزادانه از آنها استفاده کرد و اکنون بهعنوان بخشی از فهرست بستهبندی چارچوب Android بهطور رسمی پشتیبانی میشوند. |
تست API ها |
| رابط هایی که برای آزمایش سیستم داخلی استفاده می شوند، مانند API هایی که تست را از طریق مجموعه تست سازگاری (CTS) تسهیل می کنند. APIهای آزمایشی بخشی از SDK نیستند . با شروع Android 11 (سطح API 30) ، APIهای آزمایشی در فهرست بلاک گنجانده شدهاند، بنابراین برنامهها بدون در نظر گرفتن سطح API هدفشان مجاز به استفاده از آنها نیستند. همه APIهای آزمایشی پشتیبانی نمیشوند و بدون توجه به سطح API پلتفرم، بدون اطلاع قبلی در معرض تغییر هستند. |
در حالی که می توانید از برخی از رابط های غیر SDK (بسته به سطح API هدف برنامه خود) استفاده کنید، استفاده از هر روش یا فیلد غیر SDK همیشه خطر شکستن برنامه شما را بالا می برد. اگر برنامه شما به رابطهای غیر SDK متکی است، باید برنامهریزی برای انتقال به رابطهای SDK یا گزینههای دیگر را آغاز کنید. اگر نمی توانید جایگزینی برای استفاده از یک رابط غیر SDK برای یک ویژگی در برنامه خود پیدا کنید، باید یک API عمومی جدید درخواست کنید .
تعیین کنید که یک رابط به کدام لیست تعلق دارد
لیست رابط های غیر SDK به عنوان بخشی از پلتفرم ساخته شده است. برای اطلاعات در مورد هر نسخه اندروید به بخش های زیر مراجعه کنید.
Android 16 (پیشنمایش برنامهنویس)
برای اندروید 16، میتوانید فایل زیر را دانلود کنید که تمام رابطهای غیر SDK و لیستهای مربوط به آنها را توضیح میدهد:
فایل: hiddenapi-flags.csv
SHA-256 checksum: a22d5c2fa9c24ec0b864f0680208e9794222d1921114abe3245979143ce6d1c6
برای کسب اطلاعات بیشتر در مورد تغییرات لیست API غیر SDK در Android 16، به به روز رسانی محدودیت های رابط غیر SDK در Android 16 مراجعه کنید.
اندروید 15
برای Android 15 (سطح API 35)، میتوانید فایل زیر را دانلود کنید که تمام رابطهای غیر SDK و لیستهای مربوط به آنها را توضیح میدهد:
فایل: hiddenapi-flags.csv
SHA-256 checksum: 40134e205e58922a708c453726b279a296e6a1f34a988abd90cec0f3432ea5a9
برای کسب اطلاعات بیشتر در مورد تغییرات لیست API غیر SDK در Android 15، به به روز رسانی محدودیت های رابط غیر SDK در Android 15 مراجعه کنید.
اندروید 14
برای Android 14 (سطح API 34)، میتوانید فایل زیر را دانلود کنید که تمام رابطهای غیر SDK و لیستهای مربوط به آنها را توضیح میدهد:
فایل: hiddenapi-flags.csv
SHA-256 checksum: 7e00db074cbe51c51ff4b411f7b48e98692951395c5c17d069c822cc1d0eae0f
برای کسب اطلاعات بیشتر در مورد تغییرات لیست API غیر SDK در Android 14، به به روز رسانی محدودیت های رابط غیر SDK در Android 14 مراجعه کنید.
اندروید 13
برای Android 13 (سطح API 33)، میتوانید فایل زیر را دانلود کنید که تمام رابطهای غیر SDK و لیستهای مربوط به آنها را توضیح میدهد:
فایل: hiddenapi-flags.csv
SHA-256 checksum: 233a277aa8ac475b6df61bffd95665d86aac6eb2ad187b90bf42a98f5f2a11a3
برای کسب اطلاعات بیشتر درباره تغییرات لیست API غیر SDK در Android 13، از جمله جایگزینهای API عمومی پیشنهادی برای APIهایی که به طور مشروط در Android 13 مسدود شدهاند، به بهروزرسانیهای محدودیتهای رابط غیر SDK در Android 13 مراجعه کنید.
اندروید 12
برای Android 12 (سطح API 31)، میتوانید فایل زیر را دانلود کنید که همه رابطهای غیر SDK و لیستهای مربوط به آنها را توضیح میدهد:
فایل: hiddenapi-flags.csv
SHA-256 checksum: 40674ff4291eb268f86561bf687e69dbd013df9ec9531a460404532a4ac9a761
برای کسب اطلاعات بیشتر درباره تغییرات لیست API غیر SDK در Android 12، از جمله جایگزینهای عمومی پیشنهادی API برای APIهایی که به طور مشروط در Android 12 مسدود شدهاند، به فهرست تغییرات برای Android 12 مراجعه کنید.
اندروید 11
برای Android 11 (سطح API 30)، میتوانید فایل زیر را دانلود کنید که همه رابطهای غیر SDK و لیستهای مربوط به آنها را توضیح میدهد:
فایل: hiddenapi-flags.csv
SHA-256 checksum: a19d839f4f61dc9c94960ae977b2e0f3eb30f880ba1ffe5108e790010b477a56
برای کسب اطلاعات بیشتر در مورد تغییرات لیست API غیر SDK در Android 11، از جمله جایگزینهای API عمومی پیشنهادی برای APIهایی که به طور مشروط در Android 11 مسدود شدهاند، به فهرست تغییرات برای Android 11 مراجعه کنید.
اندروید 10
برای Android 10 (سطح API 29)، میتوانید فایل زیر را دانلود کنید که تمام رابطهای غیر SDK و لیستهای مربوط به آنها را توضیح میدهد:
فایل: hiddenapi-flags.csv
SHA-256 checksum: f22a59c215e752777a114bd9b07b0b6b4aedfc8e49e6efca0f99681771c5bfeb
برای کسب اطلاعات بیشتر در مورد تغییرات لیست API غیر SDK در Android 10، از جمله جایگزینهای API عمومی پیشنهادی برای APIهایی که به طور مشروط در Android 10 مسدود شدهاند، به فهرست تغییرات برای Android 10 مراجعه کنید.
اندروید 9
برای Android 9 (سطح API 28)، فایل متنی زیر حاوی لیستی از APIهای غیر SDK است که محدود نیستند (فهرست خاکستری): hiddenapi-light-greylist.txt
.
لیست بلاک ( blacklist
) و لیست APIهای مسدود شده مشروط (فهرست خاکستری تیره) در زمان ساخت مشتق می شوند.
ایجاد لیست از AOSP
هنگام کار با AOSP، میتوانید یک فایل hiddenapi-flags.csv
ایجاد کنید که حاوی تمام رابطهای غیر SDK و لیستهای مربوط به آنها است. برای انجام این کار، منبع AOSP را دانلود کنید و سپس دستور زیر را اجرا کنید:
m out/soong/hiddenapi/hiddenapi-flags.csv
سپس می توانید فایل را در مکان زیر پیدا کنید:
out/soong/hiddenapi/hiddenapi-flags.csv
رفتار مورد انتظار هنگام دسترسی به رابطهای غیر SDK محدود
جدول زیر رفتاری را توصیف میکند که میتوانید در صورت تلاش برنامه شما برای دسترسی به یک رابط غیر SDK که بخشی از فهرست مسدود است، انتظار داشته باشید.
وسیله دسترسی | نتیجه |
---|---|
دستورالعمل دالویک به یک فیلد ارجاع می دهد | NoSuchFieldError پرتاب شد |
دستورالعمل دالویک به یک روش ارجاع می دهد | NoSuchMethodError پرتاب شد |
بازتاب با استفاده از Class.getDeclaredField() یا Class.getField() | NoSuchFieldException پرتاب شد |
بازتاب با استفاده از Class.getDeclaredMethod() , Class.getMethod() | NoSuchMethodException پرتاب شد |
بازتاب با استفاده از Class.getDeclaredFields() , Class.getFields() | اعضای غیر SDK در نتایج نیستند |
بازتاب با استفاده از Class.getDeclaredMethods() , Class.getMethods() | اعضای غیر SDK در نتایج نیستند |
JNI با استفاده از env->GetFieldID() | NULL برگشت، NoSuchFieldError پرتاب شد |
JNI با استفاده از env->GetMethodID() | NULL برگشت، NoSuchMethodError پرتاب شد |
برنامه خود را برای رابط های غیر SDK آزمایش کنید
چندین روش وجود دارد که میتوانید از آنها برای آزمایش رابطهای غیر SDK در برنامه خود استفاده کنید.
با استفاده از یک برنامه اشکال زدایی تست کنید
میتوانید رابطهای غیر SDK را با ساختن و اجرای یک برنامه قابل اشکالزدایی روی دستگاه یا شبیهساز دارای Android 9 (سطح API 28) یا بالاتر آزمایش کنید. مطمئن شوید که دستگاه یا شبیهسازی که استفاده میکنید با سطح API هدف برنامه شما مطابقت داشته باشد.
در حین اجرای آزمایشها بر روی برنامه شما، اگر برنامه شما به رابطهای غیر SDK خاصی دسترسی پیدا کند، سیستم یک پیام گزارش چاپ میکند. برای یافتن جزئیات زیر میتوانید پیامهای گزارش برنامه خود را بررسی کنید:
- کلاس، نام و نوع اعلان کننده (در قالبی که در زمان اجرا اندروید استفاده می شود).
- ابزار دسترسی: یا پیوند دادن، با استفاده از بازتاب یا استفاده از JNI.
- رابط غیر SDK به کدام لیست تعلق دارد.
میتوانید از adb logcat
برای دسترسی به این پیامهای گزارش، که در زیر PID برنامه در حال اجرا ظاهر میشوند، استفاده کنید. به عنوان مثال، یک ورودی در گزارش ممکن است به صورت زیر باشد:
Accessing hidden field Landroid/os/Message;->flags:I (light greylist, JNI)
با استفاده از StrictMode API تست کنید
همچنین میتوانید رابطهای غیر SDK را با استفاده از StrictMode
API آزمایش کنید. برای فعال کردن آن از روش detectNonSdkApiUsage
استفاده کنید. پس از فعال کردن StrictMode
API، میتوانید برای هر استفاده از یک رابط غیر SDK با استفاده از penaltyListener
یک تماس پاسخ دریافت کنید، جایی که میتوانید مدیریت سفارشی را پیادهسازی کنید. شیء Violation
ارائه شده در callback از Throwable
مشتق شده است و ردیابی پشته محصور زمینه استفاده را فراهم می کند.
با استفاده از ابزار veridex تست کنید
همچنین می توانید ابزار تجزیه و تحلیل استاتیک veridex را بر روی APK خود اجرا کنید. ابزار veridex کل پایگاه کد APK از جمله کتابخانه های شخص ثالث را اسکن می کند و هرگونه استفاده از رابط های غیر SDK را که پیدا می کند گزارش می دهد.
محدودیت های ابزار veridex شامل موارد زیر است:
- نمیتواند فراخوانها را از طریق JNI شناسایی کند.
- فقط می تواند زیر مجموعه ای از فراخوان ها را از طریق بازتاب تشخیص دهد.
- تجزیه و تحلیل آن برای مسیرهای کد غیرفعال به بررسی سطح API محدود می شود.
- فقط میتواند روی ماشینهایی اجرا شود که دستورالعملهای SSE4.2 و POPCNT را پشتیبانی میکنند.
ویندوز
باینری های بومی ویندوز ارائه نشده اند، اما می توانید ابزار veridex را با اجرای باینری های لینوکس با استفاده از زیرسیستم ویندوز برای لینوکس (WSL) در ویندوز اجرا کنید. قبل از انجام مراحل این بخش، WSL را نصب کرده و Ubuntu را به عنوان توزیع لینوکس خود انتخاب کنید.
پس از نصب اوبونتو، ترمینال اوبونتو را راه اندازی کنید و مراحل زیر را دنبال کنید:
- ابزار veridex را از مخزن از پیش ساخته شده در زمان اجرا اندروید دانلود کنید.
- محتویات فایل
appcompat.tar.gz
را استخراج کنید. - در پوشه استخراج شده، فایل
veridex-linux.zip
را پیدا کرده و آن را استخراج کنید. به پوشه زیپ نشده بروید و سپس دستور زیر را اجرا کنید، جایی که
your-app.apk
APKی است که می خواهید آزمایش کنید:./appcompat.sh --dex-file=your-app.apk
macOS
برای اجرای ابزار veridex در macOS، مراحل زیر را دنبال کنید:
- ابزار veridex را از مخزن از پیش ساخته شده در زمان اجرا اندروید دانلود کنید.
- محتویات فایل
appcompat.tar.gz
را استخراج کنید. - در پوشه استخراج شده، فایل
veridex-mac.zip
را پیدا کرده و آن را استخراج کنید. به پوشه زیپ نشده بروید و سپس دستور زیر را اجرا کنید، جایی که
/path-from-root/your-app.apk
مسیر APK است که می خواهید آزمایش کنید، از دایرکتوری ریشه سیستم شما شروع می شود:./appcompat.sh --dex-file=/path-from-root/your-app.apk
لینوکس
برای اجرای ابزار veridex در لینوکس، مراحل زیر را دنبال کنید:
- ابزار veridex را از مخزن از پیش ساخته شده در زمان اجرا اندروید دانلود کنید.
- محتویات فایل
appcompat.tar.gz
را استخراج کنید. - در پوشه استخراج شده، فایل
veridex-linux.zip
را پیدا کرده و آن را استخراج کنید. به پوشه زیپ نشده بروید و سپس دستور زیر را اجرا کنید، جایی که
your-app.apk
APKی است که می خواهید آزمایش کنید:./appcompat.sh --dex-file=your-app.apk
با استفاده از ابزار لینت اندروید استودیو تست کنید
هر زمان که برنامه خود را در Android Studio میسازید، ابزار lint کد شما را برای مشکلات احتمالی بررسی میکند. اگر برنامه شما از رابطهای غیر SDK استفاده میکند، بسته به اینکه آن رابطها به کدام فهرست تعلق دارند، ممکن است خطاهای ساخت یا هشدارهایی را مشاهده کنید.
همچنین می توانید ابزار lint را از خط فرمان اجرا کنید یا بازرسی ها را به صورت دستی روی یک پروژه، پوشه یا فایل خاص اجرا کنید .
با استفاده از کنسول Play تست کنید
هنگامی که برنامه خود را در یک مسیر آزمایشی در Play Console آپلود می کنید، برنامه شما به طور خودکار برای مشکلات احتمالی آزمایش می شود و یک گزارش پیش از راه اندازی ایجاد می شود. اگر برنامه شما از رابطهای غیر SDK استفاده میکند، بسته به اینکه آن رابطها به کدام فهرست تعلق دارند، یک خطا یا هشدار در گزارش پیش از راهاندازی نمایش داده میشود.
برای اطلاعات بیشتر، به بخش سازگاری Android در استفاده از گزارشهای پیش از راهاندازی برای شناسایی مشکلات مراجعه کنید.
یک API عمومی جدید درخواست کنید
اگر نمی توانید جایگزینی برای استفاده از رابط غیر SDK برای یک ویژگی در برنامه خود پیدا کنید، می توانید با ایجاد یک درخواست ویژگی در ردیاب مشکل ما، یک API عمومی جدید درخواست کنید.
هنگام ایجاد یک درخواست ویژگی، اطلاعات زیر را ارائه دهید:
- از کدام API پشتیبانی نشده استفاده می کنید، از جمله توصیفگر کامل که در پیام
Accessing hidden ...
دیده می شود. - چرا باید از این APIها استفاده کنید، از جمله جزئیات مربوط به ویژگی سطح بالایی که API برای آن ضروری است، نه فقط جزئیات سطح پایین.
- چرا هر API SDK عمومی مرتبط برای اهداف شما کافی نیست.
- هر جایگزین دیگری که امتحان کرده اید و چرا اینها جواب نداده اند.
وقتی این جزئیات را در درخواست ویژگی خود ارائه می کنید، احتمال اعطای یک API عمومی جدید را افزایش می دهید.
سوالات دیگر
این بخش شامل برخی از پاسخها به سوالات دیگری است که توسعهدهندگان اغلب پرسیدهاند:
سوالات عمومی
چگونه گوگل میتواند مطمئن باشد که میتواند نیازهای همه برنامهها را از طریق ردیاب صادر کند؟
ما لیست های اولیه را برای Android 9 (سطح API 28) از طریق تجزیه و تحلیل استاتیک برنامه ها ایجاد کردیم که با استفاده از روش های زیر تکمیل شد:
- تست دستی برنامه های برتر Play و غیر Play
- گزارش های داخلی
- جمع آوری خودکار داده ها از کاربران داخلی
- گزارش های پیش نمایش توسعه دهندگان
- تجزیه و تحلیل استاتیک اضافی که به گونه ای محافظه کارانه شامل موارد مثبت کاذب بیشتری طراحی شده است
همانطور که لیست ها را برای هر نسخه جدید ارزیابی می کنیم، استفاده از API و همچنین بازخورد توسعه دهندگان را از طریق ردیاب مشکل در نظر می گیریم.
چگونه می توانم دسترسی به رابط های غیر SDK را فعال کنم؟
میتوانید با استفاده از دستورات adb برای تغییر خطمشی اجرای API، دسترسی به رابطهای غیر SDK را در دستگاههای توسعه فعال کنید. دستوراتی که استفاده می کنید بسته به سطح API متفاوت است. این دستورات به دستگاه روت شده نیاز ندارند.
- Android 10 (سطح API 29) یا بالاتر
برای فعال کردن دسترسی، از adb زیر استفاده کنید
دستور:
adb shell settings put global hidden_api_policy 1
برای بازنشانی سیاست اجرایی API به تنظیمات پیش فرض، از دستور زیر استفاده کنید:
adb shell settings delete global hidden_api_policy
- Android 9 (سطح API 28)
برای فعال کردن دسترسی، از دستورات adb زیر استفاده کنید:
adb shell settings put global hidden_api_policy_pre_p_apps 1
adb shell settings put global hidden_api_policy_p_apps 1
برای بازنشانی سیاست اجرای API به تنظیمات پیش فرض، از دستورات زیر استفاده کنید:
adb shell settings delete global hidden_api_policy_pre_p_apps
adb shell settings delete global hidden_api_policy_p_apps
می توانید عدد صحیح را در خط مشی اجرای API روی یکی از مقادیر زیر تنظیم کنید:
- 0: همه شناسایی رابط های غیر SDK را غیرفعال کنید. استفاده از این تنظیم همه پیامهای گزارش را برای استفاده از رابط غیر SDK غیرفعال میکند و از آزمایش برنامه خود با استفاده از
StrictMode
API جلوگیری میکند. این تنظیم توصیه نمی شود. - 1: دسترسی به تمام رابطهای غیر SDK را فعال کنید، اما پیامهای گزارش را با اخطار برای هر گونه استفاده از رابط غیر SDK چاپ کنید. استفاده از این تنظیم همچنین به شما امکان میدهد برنامه خود را با استفاده از
StrictMode
API آزمایش کنید. - 2: استفاده از واسطهای غیر SDK را که به فهرست بلاک تعلق دارند یا به صورت مشروط برای سطح API هدف شما مسدود شدهاند، ممنوع کنید.
سوالاتی در مورد لیست های رابط غیر SDK
از کجا می توانم لیست های غیر SDK API را در تصویر سیستم پیدا کنم؟
آنها در فیلد و بیت های پرچم دسترسی به روش در فایل های dex پلت فرم کدگذاری می شوند. هیچ فایل جداگانه ای در تصویر سیستم که حاوی این لیست ها باشد وجود ندارد.
آیا لیستهای غیر SDK API در دستگاههای OEM مختلف با نسخههای Android یکسان یکسان هستند؟
OEM ها می توانند واسط های خود را به لیست بلاک (لیست سیاه) اضافه کنند، اما نمی توانند رابط ها را از لیست های AOSP غیر SDK API حذف کنند. CDD از چنین تغییراتی جلوگیری میکند و تستهای CTS اطمینان حاصل میکنند که Android Runtime لیست را اجرا میکند.
سوالاتی در مورد سازگاری برنامه های مرتبط
آیا محدودیتی برای رابط های غیر NDK در کد بومی وجود دارد؟
Android SDK شامل رابط های جاوا است. این پلتفرم شروع به محدود کردن دسترسی به رابط های غیر NDK برای کدهای C/C++ در اندروید 7 (سطح API 26) کرد. برای اطلاعات بیشتر، به بهبود پایداری با محدودیتهای نماد C/C++ خصوصی در Android N مراجعه کنید.
آیا برنامه ای برای محدود کردن دستکاری فایل های dex2oat یا DEX وجود دارد؟
ما برنامههای فعالی برای محدود کردن دسترسی به باینری dex2oat نداریم، اما قصد نداریم که قالب فایل DEX پایدار باشد یا یک رابط عمومی فراتر از بخشهایی که به طور عمومی در قالب اجرایی Dalvik مشخص شدهاند. ما حق تغییر یا حذف dex2oat و بخش های نامشخص فرمت DEX را در هر زمان برای خود محفوظ می داریم. همچنین توجه داشته باشید که فایل های مشتق شده توسط dex2oat مانند ODEX (همچنین به عنوان OAT شناخته می شود)، VDEX و CDEX همگی فرمت های نامشخصی هستند.
اگر یک SDK شخص ثالث حیاتی (به عنوان مثال، یک مبهم) نتواند از استفاده از رابط های غیر SDK اجتناب کند، اما آیا متعهد به حفظ سازگاری با نسخه های اندروید آینده است، چه؟ آیا اندروید در این مورد می تواند از الزامات سازگاری خود چشم پوشی کند؟
ما برنامه ای برای چشم پوشی از الزامات سازگاری بر اساس هر SDK نداریم. اگر یک توسعهدهنده SDK فقط میتواند با بسته به واسطهای موجود در فهرستهای پشتیبانینشده (خاکستری سابق) سازگاری خود را حفظ کند، باید برنامهریزی انتقال به رابطهای SDK یا سایر گزینههای جایگزین را آغاز کند و هر زمان که نتوانست جایگزینی برای استفاده از یک غیرمستقیم پیدا کند ، یک API عمومی جدید درخواست کند. -رابط SDK
آیا محدودیتهای رابط غیر SDK برای همه برنامهها از جمله برنامههای سیستم و شخص اول اعمال میشود، نه فقط برنامههای شخص ثالث؟
بله، با این حال، ما برنامههایی را که با کلید پلتفرم امضا شدهاند و برخی از برنامههای تصویر سیستم معاف میکنیم. توجه داشته باشید که این معافیت ها فقط برای برنامه هایی اعمال می شود که بخشی از تصویر سیستم (یا برنامه های تصویر سیستم به روز شده) هستند. این لیست فقط برای برنامههایی در نظر گرفته شده است که بر اساس APIهای پلتفرم خصوصی ساخته میشوند، نه APIهای SDK (که در آن LOCAL_PRIVATE_PLATFORM_APIS := true
).