साथ काम करने के फ़्रेमवर्क में बदलाव (Android 11)

इस पेज पर, ऐप्लिकेशन पर असर डालने वाले हर उस बदलाव के बारे में बताया गया है जिसे Android 11 (एपीआई लेवल 30) में, कंपैटिबिलिटी फ़्रेमवर्क में जोड़ा गया था. Android 11 के साथ काम करने वाले ऐप्लिकेशन को तैयार करने के दौरान, इस सूची का इस्तेमाल डेवलपर के लिए सेटिंग और टूल और एडीबी कमांड के साथ करें. इससे आपको अपने ऐप्लिकेशन की जांच करने और उसे डीबग करने में मदद मिलेगी.

ADD_CONTENT_OBSERVER_FLAGS

आईडी बदलें: 150939131

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 को टारगेट करने वाले ऐप्लिकेशन के लिए, एक नया सार्वजनिक एपीआई ओवरलोड onChange(boolean, Uri, int) उपलब्ध है. इसमें एक पूर्णांक flags आर्ग्युमेंट शामिल है.

यह नया तरीका, सार्वजनिक एसडीके का विकल्प है. यह उन ऐप्लिकेशन के लिए है जो गैर-एसडीके onChange() ओवरलोड किए गए ऐसे तरीके का इस्तेमाल करते हैं जिसमें पूर्णांक userId आर्ग्युमेंट शामिल होता है.

ADMIN_APP_PASSWORD_COMPLEXITY

आईडी बदलें: 123562444

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 को टारगेट करने वाले एडमिन ऐप्लिकेशन के लिए, जब भी कोई ऐप्लिकेशन पासवर्ड से जुड़ी ऐसी ज़रूरी शर्त सेट करता है जो फ़िलहाल असाइन किए गए पासवर्ड की क्वालिटी से मेल नहीं खाती, तब गड़बड़ी का मैसेज दिखाएं. उदाहरण के लिए, जब पासवर्ड की क्वालिटी DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED पर सेट होती है, तो कोई ऐप्लिकेशन पासवर्ड की कम से कम लंबाई सेट नहीं कर पाएगा. इस मामले में, पासवर्ड की कम से कम लंबाई सेट करने से पहले, ऐप्लिकेशन को सबसे पहले setPasswordQuality() तरीके को कॉल करना चाहिए. इसके बाद ही, उसे setPasswordMinimumLength() तरीके को कॉल करना चाहिए.

इसके अलावा, जब Android 11 को टारगेट करने वाला कोई एडमिन ऐप्लिकेशन, पासवर्ड की क्वालिटी को कम करता है, तो पासवर्ड से जुड़ी ऐसी सभी मौजूदा ज़रूरी शर्तों को उनकी डिफ़ॉल्ट वैल्यू पर रीसेट कर दिया जाता है जो अब लागू नहीं होती हैं.

APP_DATA_DIRECTORY_ISOLATION

आईडी बदलें: 143937733

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 को टारगेट करने वाले ऐप्लिकेशन, अब किसी भी ऐप्लिकेशन की निजी डेटा डायरेक्ट्री में मौजूद फ़ाइलों को ऐक्सेस नहीं कर सकते. भले ही, दूसरे ऐप्लिकेशन का टारगेट SDK वर्शन कुछ भी हो.

ज़्यादा जानने के लिए, निजी डायरेक्ट्री का ऐक्सेस लेख पढ़ें.

APN_READING_PERMISSION_CHANGE_ID

आईडी बदलें: 124107808

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 को टारगेट करने वाले ऐप्लिकेशन के लिए, अब APN डेटाबेस को ऐक्सेस करने के लिए Manifest.permission.WRITE_APN_SETTINGS अनुमति की ज़रूरत होती है.

इस बदलाव के बारे में ज़्यादा जानने के लिए, एपीएन डेटाबेस के लिए, पढ़ने के ऐक्सेस पर पाबंदी लेख पढ़ें.

BACKGROUND_RATIONALE_CHANGE_ID

आईडी बदलें: 147316723

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

अब ऐप्लिकेशन को हर बार, डिवाइस की जगह की जानकारी को बैकग्राउंड में ऐक्सेस करने का अनुरोध करते समय, इसकी वजह बतानी होगी.

इस बदलाव के बारे में ज़्यादा जानने के लिए, Android 11 में बैकग्राउंड में जगह की जानकारी ऐक्सेस करने के तरीके के बारे में बताने वाली गाइड देखें. इसमें Android 11 में जगह की जानकारी से जुड़े निजता के बदलावों के बारे में बताया गया है.

CALLBACK_ON_CLEAR_CHANGE

आईडी बदलें: 119147584

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

जब भी Editor.clear को कॉल किया जाता है, तब null कुंजी के साथ OnSharedPreferenceChangeListener.onSharedPreferenceChanged को कॉलबैक किया जाता है.

इस बदलाव के बारे में ज़्यादा जानने के लिए, OnSharedPreferenceChangeListener के लिए कॉलबैक में हुए बदलाव देखें.

CALLBACK_ON_MORE_ERROR_CODE_CHANGE

आईडी बदलें: 130595455

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

अब updateAvailableNetworks(List, Executor, Consumer) और setPreferredOpportunisticDataSubscription(int, boolean, Executor, Consumer) के लिए, गड़बड़ी कोड की जानकारी ज़्यादा दी गई है.

CALL_BACK_ON_CHANGED_LISTENER_WITH_SWITCHED_OP_CHANGE

आईडी बदलें: 148180766

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

startWatchingMode(String, String, AppOpsManager.OnOpChangedListener) के व्यवहार में यह मामूली बदलाव किया गया है. इस बदलाव से पहले, सिस्टम उस ऑपरेशन के लिए वापस कॉल करता था जिसे स्विच किया गया था. बदलाव के बाद, सिस्टम उस ऑपरेशन के लिए वापस कॉल करेगा जिसका अनुरोध किया गया था. अगर कोई ऑपरेशन नहीं बताया गया है, तो सिस्टम उन सभी ऑपरेशन के लिए वापस कॉल करेगा जिन्हें स्विच किया गया था.

CAMERA_MICROPHONE_CAPABILITY_CHANGE_ID

आईडी बदलें: 136219221

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 को टारगेट करने वाले ऐप्लिकेशन के लिए, फ़ोरग्राउंड सेवाओं को सिर्फ़ तब कैमरे और माइक्रोफ़ोन के इस्तेमाल की अनुमति मिलती है, जब मेनिफ़ेस्ट फ़ाइल में R.attr.foregroundServiceType को ServiceInfo.FOREGROUND_SERVICE_TYPE_CAMERA और ServiceInfo.FOREGROUND_SERVICE_TYPE_MICROPHONE के तौर पर कॉन्फ़िगर किया गया हो. Android के पुराने वर्शन में, फ़ोरग्राउंड सेवाओं को कैमरे और माइक्रोफ़ोन की सुविधाएं अपने-आप मिल जाती थीं.

इस बदलाव के बारे में ज़्यादा जानने के लिए, Android 11 में फ़ोरग्राउंड सेवाओं के टाइप देखें.

CHANGE_BACKGROUND_CUSTOM_TOAST_BLOCK

आईडी बदलें: 128611929

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

ऐप्लिकेशन अब बैकग्राउंड में कस्टम सूचनाएं पोस्ट नहीं कर सकते. हालांकि, बैकग्राउंड में होने पर भी ऐप्लिकेशन, Toast.makeText(Context, CharSequence, int) तरीके और इसके वैरिएंट का इस्तेमाल करके सूचनाएं पोस्ट कर सकते हैं.

इस बदलाव के बारे में ज़्यादा जानने के लिए, कस्टम टोस्ट व्यू ब्लॉक कर दिए गए हैं लेख पढ़ें.

CHANGE_RESTRICT_SAW_INTENT

आईडी बदलें: 135920175

डिफ़ॉल्ट स्थिति: इस बदलाव को टॉगल नहीं किया जा सकता. इसे सिर्फ़ कंपैटबिलिटी फ़्रेमवर्क लॉग करता है.

android.settings.MANAGE_APP_OVERLAY_PERMISSION कार्रवाई और package डेटा यूआरआई स्कीम का इस्तेमाल करने वाले इंटेंट, अब उपयोगकर्ता को ऐप्लिकेशन से जुड़ी अनुमति मैनेज करने के लिए, ऐप्लिकेशन की स्क्रीन पर रीडायरेक्ट नहीं करते हैं. इसके बजाय, उपयोगकर्ता को एक ऐसी स्क्रीन पर ले जाया जाता है जहां वे उन सभी ऐप्लिकेशन को मैनेज कर सकते हैं जिन्होंने अनुमति का अनुरोध किया है.

पर जाएं.

CHANGE_TEXT_TOASTS_IN_THE_SYSTEM

आईडी बदलें: 147798919

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

अब टेक्स्ट वाले सूचना मैसेज, ऐप्लिकेशन में नहीं बल्कि SystemUI में रेंडर किए जाते हैं. इससे ऐप्लिकेशन, बैकग्राउंड में कस्टम सूचना मैसेज पोस्ट करने से जुड़ी पाबंदियों को नहीं तोड़ पाएंगे.

DEFAULT_SCOPED_STORAGE

आईडी बदलें: 149924527

डिफ़ॉल्ट स्थिति: सभी ऐप्लिकेशन के लिए चालू है.

Android 11 को टारगेट करने वाले सभी ऐप्लिकेशन, अब डिफ़ॉल्ट रूप से स्कोप किए गए स्टोरेज का इस्तेमाल करते हैं. साथ ही, अब वे स्कोप किए गए स्टोरेज से ऑप्ट आउट नहीं कर सकते.

हालांकि, इस बदलाव को बंद करके, स्कोप किए गए स्टोरेज के बिना अपने ऐप्लिकेशन को टेस्ट किया जा सकता है. इससे कोई फ़र्क़ नहीं पड़ता कि आपके ऐप्लिकेशन के टारगेट एसडीके का वर्शन क्या है और मेनिफ़ेस्ट फ़्लैग की वैल्यू क्या हैं.

Android 11 में स्कोप किए गए स्टोरेज में हुए बदलावों के बारे में ज़्यादा जानने के लिए, Android 11 में Android स्टोरेज में हुए बदलावों के बारे में जानकारी देने वाले पेज पर जाएं. इसके बाद, स्कोप किया गया स्टोरेज सेक्शन देखें.

EMPTY_INTENT_ACTION_CATEGORY

बदलाव का आईडी: 151163173

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 को टारगेट करने वाले ऐप्लिकेशन के लिए, अगर इंटेंट फ़िल्टर का action या category खाली स्ट्रिंग है, तो सिस्टम अब गड़बड़ी दिखाएगा. Android 11 से पहले के वर्शन में, प्लैटफ़ॉर्म में मौजूद एक बग की वजह से, इस मामले में कोई गड़बड़ी नहीं हुई. ध्यान दें कि इसमें ऐसे मामले शामिल नहीं हैं जिनमें एट्रिब्यूट की वैल्यू शून्य हो या वह मौजूद न हो. ऐसा इसलिए, क्योंकि इन मामलों में हमेशा गड़बड़ी होती है.

FILTER_APPLICATION_QUERY

आईडी बदलें: 135549675

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

अब ऐप्लिकेशन को उन पैकेज और इंटेंट के बारे में बताना होगा जिनका इस्तेमाल वे करना चाहते हैं. इसके बाद ही, उन्हें डिवाइस पर मौजूद अन्य ऐप्लिकेशन के बारे में जानकारी मिल पाएगी. इस तरह की जानकारी, ऐप्लिकेशन के मेनिफ़ेस्ट में <queries> टैग का इस्तेमाल करके दी जानी चाहिए.

Android 11 में, इंस्टॉल किए गए अन्य ऐप्लिकेशन से क्वेरी करने और उनके साथ इंटरैक्ट करने के तरीके के बारे में ज़्यादा जानने के लिए, packageVisibility निजता पेज देखें.

FORCE_ENABLE_SCOPED_STORAGE

बदलाव का आईडी: वैल्यू: 132649864

डिफ़ॉल्ट स्थिति: सभी ऐप्लिकेशन के लिए बंद है.

Android 11 को टारगेट करने वाले सभी ऐप्लिकेशन, अब डिफ़ॉल्ट रूप से स्कोप किए गए स्टोरेज का इस्तेमाल करते हैं. साथ ही, अब वे स्कोप किए गए स्टोरेज से ऑप्ट आउट नहीं कर सकते.

हालांकि, अगर आपका ऐप्लिकेशन अब भी Android 10 (एपीआई लेवल 29) या इससे पहले के वर्शन को टारगेट करता है, तो इस बदलाव को चालू करके, स्कोप्ड स्टोरेज के साथ अपने ऐप्लिकेशन को टेस्ट किया जा सकता है. भले ही, आपके ऐप्लिकेशन का टारगेट एसडीके वर्शन और मेनिफ़ेस्ट फ़्लैग की वैल्यू कुछ भी हो.

Android 11 में स्कोप किए गए स्टोरेज में हुए बदलावों के बारे में ज़्यादा जानने के लिए, Android 11 में Android स्टोरेज में हुए बदलावों के बारे में जानकारी देने वाले पेज पर जाएं. इसके बाद, स्कोप किया गया स्टोरेज सेक्शन देखें.

GET_DATA_CONNECTION_STATE_R_VERSION

आईडी बदलें: 148535736

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

PreciseDataConnectionState#getDataConnectionState के लिए एसडीके का वर्शन देखने के लिए.

GET_DATA_STATE_R_VERSION

बदलाव का आईडी: 148534348

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

getDataState() के लिए, एसडीके का वर्शन देखने के लिए.

GET_PROVIDER_SECURITY_EXCEPTIONS

आईडी बदलें: 150935354

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 (एपीआई लेवल 30) या उसके बाद के वर्शन को टारगेट करने वाले ऐप्लिकेशन के लिए, getProvider(String) अब कोई सुरक्षा अपवाद नहीं दिखाता है.

GET_TARGET_SDK_VERSION_CODE_CHANGE

आईडी बदलें: 145147528

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 10 (एपीआई लेवल 29) या इसके बाद के वर्शन को टारगेट करते हैं.

SmsManager.sendResolverResult() तरीके के लिए एसडीके टूल का वर्शन देखने के लिए.

GWP_ASAN

आईडी बदलें: 135634846

डिफ़ॉल्ट स्थिति: सभी ऐप्लिकेशन के लिए बंद है.

इस सेटिंग से, ऐप्लिकेशन में सैंपल आधारित नेटिव मेमोरी से जुड़ी गड़बड़ी की पहचान करने की सुविधा चालू होती है.

इस बदलाव के बारे में ज़्यादा जानने के लिए, GWP-ASan गाइड देखें.

HIDE_MAXTARGETSDK_P_HIDDEN_APIS

आईडी बदलें: 149997251

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 10 (एपीआई लेवल 29) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 10 (एपीआई लेवल 29) या इसके बाद के वर्शन को टारगेट करने वाले ऐप्लिकेशन के लिए, Android 10 (एपीआई लेवल 29) की max-target-p (greylist-max-p) सूची में शामिल सभी गैर-एसडीके इंटरफ़ेस का ऐक्सेस हटा देता है.

HIDE_MAXTARGETSDK_Q_HIDDEN_APIS

बदलाव का आईडी: 149994052

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करने वाले ऐप्लिकेशन के लिए, max-target-q (greylist-max-q) सूची में शामिल सभी गैर-एसडीके इंटरफ़ेस का ऐक्सेस हटा देता है. यह सूची, Android 11 (एपीआई लेवल 30) के लिए है.

इस बदलाव के बारे में ज़्यादा जानने के लिए, ऐसे गैर-एसडीके इंटरफ़ेस जिन्हें अब Android 11 में ब्लॉक कर दिया गया है लेख पढ़ें.

LISTEN_CODE_CHANGE

आईडी बदलें: 147600208

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 10 (एपीआई लेवल 29) या इसके बाद के वर्शन को टारगेट करते हैं.

TelephonyManager.listen(PhoneStateListener, int) के लिए एसडीके का वर्शन देखने के लिए.

MISSING_APP_TAG

आईडी बदलें: 150776642

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 को टारगेट करने वाले ऐप्लिकेशन के लिए, अब गड़बड़ी तब दिखती है, जब ऐप्लिकेशन की मेनिफ़ेस्ट फ़ाइल में application या instrumentation टैग मौजूद नहीं होता.

NATIVE_HEAP_POINTER_TAGGING

आईडी बदलें: 135754954

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 को टारगेट करने वाले ऐप्लिकेशन के लिए, नेटिव हीप के लिए मेमोरी असाइनमेंट में अब सबसे अहम बाइट में नॉन-ज़ीरो टैग होता है.

ज़्यादा जानने के लिए, हीप पॉइंटर टैगिंग देखें.

PHONE_STATE_LISTENER_LIMIT_CHANGE_ID

आईडी बदलें: 150880553

डिफ़ॉल्ट स्थिति: सभी ऐप्लिकेशन के लिए चालू है.

Android 11 को टारगेट करने वाले ऐप्लिकेशन के लिए, अब TelephonyManager.listen(PhoneStateListener, int) के ज़रिए रजिस्टर किए जा सकने वाले PhoneStateListener ऑब्जेक्ट की संख्या सीमित कर दी गई है. डिफ़ॉल्ट सीमा 50 है. इसे डिवाइस के कॉन्फ़िगरेशन को अपडेट करके बदला जा सकता है. इस सीमा को लागू करने के लिए, TelephonyManager.listen(PhoneStateListener, int) से मिले IllegalStateException का इस्तेमाल किया जाता है. ऐसा तब होता है, जब उल्लंघन करने वाली प्रोसेस बहुत ज़्यादा लिसनर रजिस्टर करने की कोशिश करती है.

PREVENT_META_REFLECTION_BLACKLIST_ACCESS

आईडी बदलें: 142365358

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 को टारगेट करने वाले ऐप्लिकेशन, अब प्रतिबंधित किए गए गैर-SDK इंटरफ़ेस को ऐक्सेस करने के लिए, रिफ़्लेक्शन की अतिरिक्त लेयर का इस्तेमाल नहीं कर सकते.

PROCESS_CAPABILITY_CHANGE_ID

आईडी बदलें: 136274596

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 को टारगेट करने वाले ऐप्लिकेशन के लिए, Context.BIND_INCLUDE_CAPABILITIES फ़्लैग का इस्तेमाल किया जा सकता है. इससे, इस्तेमाल के दौरान की जाने वाली कार्रवाइयों को क्लाइंट प्रोसेस से बाउंड सेवा में पास किया जा सकता है.

REMOVE_ANDROID_TEST_BASE

आईडी बदलें: 133396946

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 को टारगेट करने वाले ऐप्लिकेशन के लिए, अगर ऐप्लिकेशन android.test.runner पर निर्भर नहीं है, तो android.test.base लाइब्रेरी हटा दी गई है. ऐसा इसलिए, क्योंकि यह android.test.base लाइब्रेरी की क्लास पर निर्भर करती है.

REQUEST_ACCESSIBILITY_BUTTON_CHANGE

बदलाव का आईडी: 136293963

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 को टारगेट करने वाली सुलभता सेवाओं के लिए, अब सुलभता सेवा की मेटाडेटा फ़ाइल में FLAG_REQUEST_ACCESSIBILITY_BUTTON फ़्लैग को शामिल करना ज़रूरी है. ऐसा न होने पर, फ़्लैग को अनदेखा कर दिया जाता है.

इस बदलाव के बारे में ज़्यादा जानने के लिए, मेटाडेटा फ़ाइल में सुलभता बटन के इस्तेमाल की जानकारी देना लेख पढ़ें.

RESOURCES_ARSC_COMPRESSED

आईडी बदलें: 132742131

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

अगर Android 11 (एपीआई लेवल 30) को टारगेट करने वाले ऐप्लिकेशन में कंप्रेस की गई resources.arsc फ़ाइल मौजूद है या यह फ़ाइल 4-बाइट बाउंड्री पर अलाइन नहीं है, तो उन्हें इंस्टॉल नहीं किया जा सकता.

इस बदलाव के बारे में ज़्यादा जानने के लिए, कंप्रेस की गई संसाधन फ़ाइलें लेख पढ़ें.

RESTRICT_STORAGE_ACCESS_FRAMEWORK

आईडी बदलें: 141600225

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

अगर आपका ऐप्लिकेशन Android 11 को टारगेट करता है और Storage Access Framework (SAF) का इस्तेमाल करता है, तो अब ACTION_OPEN_DOCUMENT और ACTION_OPEN_DOCUMENT_TREE इंटेंट ऐक्शन का इस्तेमाल करके, कुछ डायरेक्ट्री ऐक्सेस नहीं की जा सकेंगी. इन बदलावों के बारे में ज़्यादा जानने के लिए, Android 11 में स्टोरेज से जुड़े निजता अपडेट के बारे में जानकारी देने वाले पेज पर जाएं. इसके बाद, दस्तावेज़ ऐक्सेस करने से जुड़ी पाबंदियां सेक्शन देखें.

SELINUX_LATEST_CHANGES

आईडी बदलें: 143539591

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

इस बदलाव से, ऐप्लिकेशन को untrusted_app_R-targetSDk SELinux डोमेन का ऐक्सेस मिल जाता है. यह कंपैटिबिलिटी फ़्रेमवर्क में किए गए बुनियादी बदलावों में से एक है. इससे ऐप्लिकेशन, targetSdkVersion के ज़रिए नियंत्रित किए जाने वाले अन्य बदलावों को टॉगल कर सकते हैं. इसके लिए, उन्हें अपने ऐप्लिकेशन के targetSDKVersion में बदलाव करने की ज़रूरत नहीं होती. इसलिए, आपको Android 11 को टारगेट करने वाले ऐप्लिकेशन के लिए, इस बदलाव को बंद नहीं करना चाहिए. ऐसा करने पर, ऐप्लिकेशन काम नहीं करेगा.

इस बदलाव का असर उन ऐप्लिकेशन पर नहीं पड़ेगा जो शेयर किए गए उपयोगकर्ता आईडी का इस्तेमाल करते हैं.

THROW_SECURITY_EXCEPTIONS

आईडी बदलें: 147340954

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 से पहले, अनुमति से जुड़ी गड़बड़ी के लिए setEnabled एपीआई सिर्फ़ SecurityException दिखाता था. Android 11 में ऐसा नहीं होता. इसमें कई वजहों से SecurityException थ्रो किया जा सकता है. इनमें से कोई भी वजह कॉलर को नहीं बताई जाती.

एपीआई के मौजूदा तरीके को बनाए रखने के लिए, अगर Android 11 को टारगेट न करने वाले किसी ऐप्लिकेशन के लिए, लेगसी अनुमति से जुड़ी समस्या या ऐक्टर के तौर पर काम करने वाले ऐप्लिकेशन के लिए नीति लागू करने से जुड़ी समस्या होती है, तो अपवाद को IllegalStateException में बदल दिया जाता है. यह IllegalStateException, Android 11 से पहले सोर्स में मौजूद था.

USE_SET_LOCATION_ENABLED

आईडी बदलें: 117835097

डिफ़ॉल्ट स्थिति: यह सुविधा उन ऐप्लिकेशन के लिए चालू है जो Android 11 (एपीआई लेवल 30) या इसके बाद के वर्शन को टारगेट करते हैं.

Android 11 को टारगेट करने वाले एडमिन ऐप्लिकेशन, अब Settings.Secure.LOCATION_MODE सेटिंग को बदलने के लिए DevicePolicyManager.setSecureSetting(ComponentName, String, String) का इस्तेमाल नहीं कर सकते. इसके बजाय, उन्हें DevicePolicyManager.setLocationEnabled(ComponentName, boolean) का इस्तेमाल करना चाहिए.