Android की ज़रूरी जानकारी में शामिल वेक लॉक मेट्रिक का इस्तेमाल करके, अपने ऐप्लिकेशन की बैटरी परफ़ॉर्मेंस ऑप्टिमाइज़ करना
पढ़ने में 7 मिनट लगेंगे
बैटरी लाइफ़, उपयोगकर्ता अनुभव का एक अहम पहलू है. इसमें वेक लॉक की अहम भूमिका होती है. क्या आपके ऐप्लिकेशन में वेक लॉक का ज़्यादा इस्तेमाल हो रहा है? इस ब्लॉग पोस्ट में, हम वेक लॉक के बारे में जानेंगे. साथ ही, हम यह भी जानेंगे कि वेक लॉक का इस्तेमाल करने के सबसे सही तरीके कौनसे हैं. इसके अलावा, हम यह भी जानेंगे कि Play Console की मेट्रिक की मदद से, अपने ऐप्लिकेशन के व्यवहार को बेहतर तरीके से कैसे समझा जा सकता है.
Android की ज़रूरी जानकारी में, पार्शियल वेक लॉक का ज़्यादा इस्तेमाल
Play Console अब बैटरी खत्म होने की समस्या पर नज़र रखता है. इसमें, पार्शियल वेक लॉक के ज़्यादा इस्तेमाल को परफ़ॉर्मेंस के मुख्य इंडिकेटर के तौर पर ट्रैक किया जाता है.
इस सुविधा से, बैटरी की परफ़ॉर्मेंस की अहमियत बढ़ जाती है. साथ ही, परफ़ॉर्मेंस की मुख्य मेट्रिक के मौजूदा इंडिकेटर भी अहम हो जाते हैं. जैसे, उपयोगकर्ताओं को दिखने वाले क्रैश और एएनआर (ऐप्लिकेशन काम नहीं कर रहा है) की ज़्यादा संख्या.हमने वेक लॉक के ज़्यादा इस्तेमाल के लिए, ऐप्लिकेशन की खराब परफ़ॉर्मेंस का थ्रेशोल्डतय किया है. अगर 1 मार्च, 2026 से आपका टाइटल इस क्वालिटी थ्रेशोल्ड को पूरा नहीं करता है, तो हम टाइटल को, खोज के लिए उपलब्ध मुख्य प्लैटफ़ॉर्म से हटा सकते हैं. जैसे, सुझावों में से. कुछ मामलों में, हम आपके स्टोर पेज पर एक चेतावनी दिखा सकते हैं. इससे उपयोगकर्ताओं को यह पता चलेगा कि आपका ऐप्लिकेशन, बैटरी को ज़्यादा तेज़ी से खत्म कर सकता है.
Android की ज़रूरी जानकारी के खास जानकारी वाले पेज पर, वेक लॉक के ज़्यादा इस्तेमाल की चेतावनी.
मोबाइल डिवाइसों के लिए, Android की ज़रूरी जानकारी में शामिल मेट्रिक, उन वेक लॉक पर लागू होती है जिन्हें स्क्रीन बंद होने और ऐप्लिकेशन के बैकग्राउंड में चलने या फ़ोरग्राउंड सेवा चलाने के दौरान हासिल किया जाता है. हालांकि, यह मेट्रिक, उन वेक लॉक पर लागू नहीं होती जिन्हें छूट मिली हुई है. Android की ज़रूरी जानकारी में, पार्शियल वेक लॉक के ज़्यादा इस्तेमाल को तब ट्रैक किया जाता है, जब:
- वेक लॉक, 24 घंटे की अवधि में कम से कम दो घंटे तक चालू रहते हैं.
- इसका असर, 28 दिनों के औसत के हिसाब से, आपके ऐप्लिकेशन के 5% से ज़्यादा सेशन पर पड़ता है.
ऑडियो, जगह की जानकारी, और JobScheduler के उपयोगकर्ता की ओर से शुरू किए गए एपीआई से बनाए गए वेक लॉक को, वेक लॉक की गिनती में शामिल नहीं किया जाता है.
वेक लॉक के बारे में जानकारी
वेक लॉक एक ऐसा तरीका है जिससे कोई ऐप्लिकेशन, डिवाइस के सीपीयू को चालू रख सकता है. भले ही, उपयोगकर्ता डिवाइस के साथ इंटरैक्ट न कर रहा हो.
पार्शियल वेक लॉक, स्क्रीन बंद होने पर भी सीपीयू को चालू रखता है. इससे सीपीयू, कम पावर वाले "सस्पेंड" मोड में नहीं जाता. फ़ुल वेक लॉक, स्क्रीन और सीपीयू, दोनों को चालू रखता है.
पार्शियल वेक लॉक हासिल करने के दो तरीके हैं:
- ऐप्लिकेशन, किसी खास इस्तेमाल के उदाहरण के लिए, PowerManager API का इस्तेमाल करके, वेक लॉक को मैन्युअल तरीके से हासिल करता है और रिलीज़ करता है. अक्सर, इसे फ़ोरग्राउंड सेवा के साथ हासिल किया जाता है. यह प्लैटफ़ॉर्म लाइफ़साइकल एपीआई है, जिसे उपयोगकर्ता के हिसाब से काम करने के लिए बनाया गया है.
- इसके अलावा, वेक लॉक को किसी दूसरे एपीआई से हासिल किया जाता है. साथ ही, एपीआई के इस्तेमाल की वजह से, इसे ऐप्लिकेशन के लिए एट्रिब्यूट किया जाता है. इसके बारे में ज़्यादा जानकारी, सबसे सही तरीकों वाले सेक्शन में दी गई है.
वेक लॉक, उन टास्क के लिए ज़रूरी हैं जिन्हें उपयोगकर्ता शुरू करता है. जैसे, बड़ी फ़ाइल डाउनलोड करना. हालांकि, इनका ज़्यादा या गलत इस्तेमाल करने से, बैटरी तेज़ी से खत्म हो सकती है. हमने ऐसे मामले देखे हैं जिनमें ऐप्लिकेशन, वेक लॉक को घंटों तक चालू रखते हैं या उन्हें सही तरीके से रिलीज़ नहीं करते. इससे, उपयोगकर्ताओं को बैटरी तेज़ी से खत्म होने की शिकायतें मिलती हैं. ऐसा तब भी होता है, जब वे ऐप्लिकेशन के साथ इंटरैक्ट नहीं कर रहे होते हैं.
वेक लॉक के इस्तेमाल के सबसे सही तरीके
वेक लॉक के ज़्यादा इस्तेमाल की समस्या को डीबग करने के तरीके के बारे में जानने से पहले, पक्का करें कि आपने वेक लॉक के सबसे सही तरीके अपनाए हों.
इन चार अहम सवालों पर ध्यान दें.
1. क्या आपने वेक लॉक के अन्य विकल्पों के बारे में सोचा है?
पार्शियल वेक लॉक को मैन्युअल तरीके से हासिल करने से पहले, फ़्लोचार्ट में दिए गए तरीके का पालन करें:
वेक लॉक को मैन्युअल तरीके से कब हासिल करना है, यह तय करने के लिए फ़्लोचार्ट
- क्या स्क्रीन को चालू रखने की ज़रूरत है?
- हां: इसके बजाय, स्क्रीन को चालू रखने के बारे में जानकारी देने वाला दस्तावेज़ देखें
- क्या ऐप्लिकेशन, फ़ोरग्राउंड सेवा चला रहा है?
- नहीं: आपको वेक लॉक को मैन्युअल तरीके से हासिल करने की ज़रूरत नहीं है.
- क्या डिवाइस के सस्पेंड होने से, उपयोगकर्ता अनुभव पर बुरा असर पड़ता है?
- नहीं: उदाहरण के लिए, डिवाइस के चालू होने के बाद, किसी सूचना को अपडेट करने के लिए वेक लॉक की ज़रूरत नहीं होती.
- हां: अगर डिवाइस को सस्पेंड होने से रोकना ज़रूरी है, तो आगे बढ़ें. जैसे, किसी बाहरी डिवाइस के साथ लगातार कम्यूनिकेट करना.
- क्या पहले से कोई ऐसा एपीआई मौजूद है जो आपकी ओर से डिवाइस को चालू रखता है?
- अन्य एपीआई से बनाए गए वेक लॉक की पहचान करने के लिए, दस्तावेज़ अन्य एपीआई से बनाए गए वेक लॉक की पहचान करें का इस्तेमाल किया जा सकता है. इससे उन स्थितियों की पहचान की जा सकती है जहां अन्य एपीआई से वेक लॉक बनाए जाते हैं. जैसे, LocationManager.
- अगर कोई एपीआई मौजूद नहीं है, तो आखिरी सवाल पर जाएं.
- अगर आपने इन सभी सवालों के जवाब दे दिए हैं और यह तय कर लिया है कि कोई अन्य विकल्प मौजूद नहीं है, तो आपको वेक लॉक को मैन्युअल तरीके से हासिल करना चाहिए.
2. क्या आपने वेक लॉक को सही नाम दिया है?
वेक लॉक को मैन्युअल तरीके से हासिल करते समय, डीबग करने के लिए सही नाम देना ज़रूरी है:
- नाम में, व्यक्तिगत पहचान से जुड़ी कोई भी जानकारी (पीआईआई) शामिल न करें. जैसे, ईमेल पते. अगर व्यक्तिगत पहचान से जुड़ी जानकारी का पता चलता है, तो वेक लॉक को
_UNKNOWNके तौर पर लॉग किया जाता है. इससे डीबग करने में मुश्किल होती है. - वेक लॉक को क्लास या तरीके के नामों का इस्तेमाल करके, प्रोग्राम के ज़रिए नाम न दें. ऐसा इसलिए, क्योंकि Proguard जैसे टूल की मदद से, इन्हें धुंधला किया जा सकता है. इसके बजाय, हार्ड-कोडेड स्ट्रिंग का इस्तेमाल करें.
- वेक लॉक टैग में काउंटर या यूनीक आइडेंटिफ़ायर न जोड़ें. जब भी वेक लॉक चलता है, तब एक ही टैग का इस्तेमाल किया जाना चाहिए. इससे सिस्टम, नाम के हिसाब से इस्तेमाल को इकट्ठा कर पाएगा. साथ ही, असामान्य व्यवहार का पता लगाना आसान हो जाएगा.
3. क्या हासिल किए गए वेक लॉक को हमेशा रिलीज़ किया जाता है?
अगर वेक लॉक को मैन्युअल तरीके से हासिल किया जा रहा है, तो पक्का करें कि वेक लॉक रिलीज़ हमेशा काम करे. वेक लॉक को रिलीज़ न करने पर, बैटरी तेज़ी से खत्म हो सकती है.
उदाहरण के लिए, अगर processingWork() के दौरान, कोई ऐसी गड़बड़ी होती है जिसे पकड़ा नहीं गया है, तो हो सकता है कि release() कॉल कभी न हो. इसके बजाय, try-finally ब्लॉक का इस्तेमाल करके, यह पक्का किया जा सकता है कि वेक लॉक रिलीज़ हो जाए. भले ही, कोई गड़बड़ी हो.
इसके अलावा, वेक लॉक में टाइम आउट जोड़ा जा सकता है. इससे यह पक्का किया जा सकता है कि वेक लॉक, तय समय के बाद रिलीज़ हो जाए. इससे, वेक लॉक को हमेशा के लिए चालू रहने से रोका जा सकता है.
fun processingWork() {
wakeLock.apply {
try {
acquire(60 * 10 * 1000) // timeout after 10 minutes
doTheWork()
} finally {
release()
}
}
}4. क्या वेक-अप फ़्रीक्वेंसी कम की जा सकती है?
समय-समय पर डेटा के लिए अनुरोध करने पर, बैटरी ऑप्टिमाइज़ेशन के लिए यह ज़रूरी है कि आपका ऐप्लिकेशन, डिवाइस को कितनी बार वेक अप करता है. वेक-अप फ़्रीक्वेंसी कम करने के कुछ उदाहरण यहां दिए गए हैं:
- WorkManager: PeriodicWorkRequests में, समय-समय पर होने वाले इंटरवल को बढ़ाएं.
- SensorManager: लिसनर को रजिस्टर करते समय, maxReportLatencyMs तय करके बैचिंग का फ़ायदा लें.
- कई तरह से जांची गई सही जगह की जानकारी देने वाला एपीआई:
- हाल ही में कैश की गई जगह की जानकारी के लिए, getLastLocation का इस्तेमाल करके, जगह की जानकारी पाने की फ़्रीक्वेंसी कम करें.
- बैटरी की खपत कम करने वाले अपडेट के तरीके के लिए, setPriority(PRIORITY_PASSIVE) का इस्तेमाल करें.
- इसके अलावा, setMinUpdateIntervalMillis की मदद से, कम से कम अपडेट इंटरवल सेट करके, जगह की जानकारी के बैचिंग के तरीके का फ़ायदा लिया जा सकता है.
ज़्यादा जानकारी के लिए, वेक लॉक के सबसे सही तरीकों के बारे में जानकारी देने वाला दस्तावेज़ देखें.
वेक लॉक के ज़्यादा इस्तेमाल की समस्या को डीबग करना
अच्छे इरादे होने के बावजूद, वेक लॉक का ज़्यादा इस्तेमाल हो सकता है. अगर Play Console में आपके ऐप्लिकेशन को फ़्लैग किया गया है, तो उसे डीबग करने का तरीका यहां दिया गया है:
Play Console की मदद से शुरुआती पहचान
Android की ज़रूरी जानकारी में, पार्शियल वेक लॉक के ज़्यादा इस्तेमाल की जानकारी देने वाले डैशबोर्ड पर, आपके ऐप्लिकेशन से जुड़े उन वेक लॉक के नामों की जानकारी मिलती है जिन्हें छूट नहीं मिली है. इसमें, प्रभावित सेशन और उनकी अवधि भी दिखाई जाती है. आपको यह पता लगाने में मदद करने के लिए, दस्तावेज़ का इस्तेमाल करने की सलाह दी जाती है कि वेक लॉक का नाम, ऐप्लिकेशन के पास है या किसी दूसरे एपीआई के पास.
Android की ज़रूरी जानकारी में, पार्शियल वेक लॉक के ज़्यादा इस्तेमाल की जानकारी देने वाले डैशबोर्ड को स्क्रोल करके, ब्रेकडाउन वाले सेक्शन पर ले जाया गया है, ताकि वेक लॉक के ज़्यादा इस्तेमाल वाले टैग देखे जा सकें.
वर्कर/जॉब से जुड़े वेक लॉक के ज़्यादा इस्तेमाल की समस्या को डीबग करना
इस वेक लॉक के नाम से, वर्कर से जुड़े वेक लॉक की पहचान की जा सकती है:
*job*/<package_name>/androidx.work.impl.background.systemjob.SystemJobService
वर्कर से जुड़े वेक लॉक के नामों के सभी वैरिएंट की सूची, दस्तावेज़ में उपलब्ध है. इन वेक लॉक को डीबग करने के लिए, Background Task Inspector का इस्तेमाल करके, स्थानीय तौर पर डीबग किया जा सकता है. इसके अलावा, फ़ील्ड में मौजूद समस्याओं को डीबग करने के लिए, getStopReason का इस्तेमाल किया जा सकता है.
Android Studio में Background Task Inspector
Background Task Inspector का स्क्रीनशॉट. इसमें, “WeatherSyncWorker” नाम के वर्कर की पहचान की गई है, जिसने बार-बार कोशिश की है और वह काम नहीं कर पाया है.
WorkManager से जुड़ी समस्याओं को स्थानीय तौर पर डीबग करने के लिए, एम्युलेटर या कनेक्ट किए गए डिवाइस (एपीआई लेवल 26 या इसके बाद वाला) पर इस टूल का इस्तेमाल करें. इसमें वर्कर और उनकी स्थितियों (पूरा हुआ, चल रहा है, कतार में है) की सूची दिखती है. इससे, जानकारी की समीक्षा की जा सकती है और वर्कर चेन को समझा जा सकता है.
उदाहरण के लिए, इससे यह पता चल सकता है कि सिस्टम की सीमाओं की वजह से, कोई वर्कर बार-बार काम नहीं कर पा रहा है या फिर से कोशिश कर रहा है.
ज़्यादा जानकारी के लिए, Background Task Inspector का दस्तावेज़ देखें.
WorkManager getStopReason
फ़ील्ड में, उन वर्कर को डीबग करने के लिए जिनमें वेक लॉक का ज़्यादा इस्तेमाल हो रहा है, WorkManager 2.9.0 या इसके बाद वाले वर्शन पर WorkInfo.getStopReason() का इस्तेमाल करें. वहीं, JobScheduler के लिए, SDK 31 या इसके बाद वाले वर्शन पर उपलब्ध JobParameters.getStopReason() का इस्तेमाल करें.
इस एपीआई की मदद से, यह लॉग किया जा सकता है कि कोई वर्कर क्यों रुका (उदाहरण के लिए, STOP_REASON_TIMEOUT, STOP_REASON_QUOTA). इससे, उन समस्याओं की पहचान की जा सकती है जिनकी वजह से बार-बार टाइम आउट हो रहा है. जैसे, रनटाइम की अवधि खत्म हो जाना.
backgroundScope.launch {
WorkManager.getInstance(context)
.getWorkInfoByIdFlow(workRequest.id)
.collect { workInfo ->
logStopReason(workRequest.id, workInfo?.stopReason)
}
}ज़्यादा जानकारी के लिए, टास्क शेड्यूल करने वाले एपीआई के लिए, बैटरी के इस्तेमाल को ऑप्टिमाइज़ करना लेख देखें.
वेक लॉक के ज़्यादा इस्तेमाल की अन्य समस्याओं को डीबग करना
मैन्युअल तरीके से चालू किए गए वेक लॉक या वेक लॉक को चालू रखने वाले एपीआई से जुड़ी ज़्यादा मुश्किल स्थितियों को डीबग करने के लिए, हमारा सुझाव है कि आप सिस्टम ट्रेस कलेक्शन का इस्तेमाल करें.
सिस्टम ट्रेस कलेक्शन
सिस्टम ट्रेस , डीबग करने का एक असरदार टूल है. यह एक अवधि में सिस्टम की गतिविधि का विस्तृत रिकॉर्ड कैप्चर करता है. इससे सीपीयू की स्थिति, थ्रेड गतिविधि, नेटवर्क गतिविधि, और बैटरी से जुड़ी मेट्रिक के बारे में अहम जानकारी मिलती है. जैसे, जॉब की अवधि और वेक लॉक का इस्तेमाल.
सिस्टम ट्रेस को कई तरीकों से कैप्चर किया जा सकता है:
- सिस्टम ट्रेस कमांड लाइन टूल का इस्तेमाल करना
- Android Studio CPU प्रोफ़ाइलर का इस्तेमाल करना
- Perfetto यूज़र इंटरफ़ेस (यूआई) का इस्तेमाल करना
- डेवलपर के लिए दिए गए विकल्पों से, डिवाइस पर सीधे तौर पर मैन्युअल तरीके से ट्रेस रिकॉर्ड करना .
Android ऐप्लिकेशन और svcs टैब में, Perfetto यूज़र इंटरफ़ेस (यूआई) में "power:PowerManagement" Atrace कैटगरी चालू करें.
चुने गए तरीके के बावजूद, यह पक्का करना ज़रूरी है कि आपने "power:PowerManagement" Atrace कैटगरी इकट्ठा की हो. इससे, डिवाइस की स्थिति के ट्रैक देखे जा सकते हैं.
Perfetto यूज़र इंटरफ़ेस (यूआई) की जांच और एसक्यूएल विश्लेषण
सिस्टम ट्रेस को Perfetto यूज़र इंटरफ़ेस (यूआई) में खोला और उसकी जांच की जा सकती है. ट्रेस खोलने पर, आपको टाइमलाइन पर अलग-अलग प्रोसेस का विज़ुअलाइज़ेशन दिखेगा. इस गाइड में, हमारा फ़ोकस “Device State” में मौजूद ट्रैक पर होगा.
लंबे समय तक चलने वाले वेक लॉक स्लाइस की पहचान करने के लिए, “Device State” में मौजूद ट्रैक को पिन करें. जैसे, "Top app", "Screen state", "Long Wake locks", और “Jobs” ट्रैक.
हर ब्लॉक में, इवेंट का नाम, इवेंट शुरू होने का समय, और इवेंट खत्म होने का समय दिखता है. Perfetto में, इसे स्लाइस कहा जाता है.
एक से ज़्यादा ट्रेस का विश्लेषण करने के लिए, Perfetto के एसक्यूएल विश्लेषण का इस्तेमाल किया जा सकता है. एसक्यूएल क्वेरी की मदद से, अवधि के हिसाब से क्रम में लगाए गए सभी वेक लॉक ढूंढे जा सकते हैं. इससे, वेक लॉक के ज़्यादा इस्तेमाल में योगदान देने वाले मुख्य वेक लॉक की पहचान की जा सकती है.
यहां एक उदाहरण क्वेरी दी गई है. इसमें, सिस्टम ट्रेस में हुए सभी वेक लॉक टैग को जोड़ा गया है. इन्हें कुल अवधि के हिसाब से क्रम में लगाया गया है:
SELECT slice.name as name, track.name as track_name,SUM(dur / 100000) as total_dur_ms FROM slice JOIN track ON slice.track_id = track.id WHERE track.name = 'WakeLocks'GROUP BY slice.name, track.name ORDER BY total_dur_ms DESC
फ़ील्ड में ट्रेस कलेक्शन के लिए, ProfilingManager का इस्तेमाल करना
जिन समस्याओं को फिर से नहीं दोहराया जा सकता उनके लिए, ProfilingManager (SDK 35 में जोड़ा गया) एक ऐसा एपीआई है जिसे प्रोग्राम के ज़रिए इस्तेमाल किया जा सकता है. इसकी मदद से, डेवलपर फ़ील्ड में सिस्टम ट्रेस इकट्ठा कर सकते हैं. इसके लिए, स्टार्ट और एंड ट्रिगर का इस्तेमाल किया जाता है. इससे, प्रोफ़ाइल कलेक्शन के लिए स्टार्ट और एंड ट्रिगर पॉइंट पर ज़्यादा कंट्रोल मिलता है. साथ ही, डिवाइस की परफ़ॉर्मेंस पर असर पड़ने से रोकने के लिए, सिस्टम-लेवल पर रेट लिमिटिंग लागू की जाती है.
फ़ील्ड में सिस्टम ट्रेस कलेक्शन को लागू करने के तरीके के बारे में ज़्यादा जानने के लिए, ProfilingManager का दस्तावेज़ देखें. इसमें, प्रोग्राम के ज़रिए ट्रेस कैप्चर करने, प्रोफ़ाइलिंग डेटा का विश्लेषण करने, और स्थानीय तौर पर डीबग करने के लिए कमांड इस्तेमाल करने के तरीके के बारे में जानकारी शामिल है.
ProfilingManager का इस्तेमाल करके इकट्ठा किए गए सिस्टम ट्रेस, मैन्युअल तरीके से इकट्ठा किए गए ट्रेस की तरह दिखेंगे. हालांकि, सिस्टम प्रोसेस और अन्य ऐप्लिकेशन प्रोसेस को ट्रेस से हटा दिया जाता है.
नतीजा
Android की ज़रूरी जानकारी में, पार्शियल वेक लॉक के ज़्यादा इस्तेमाल की मेट्रिक, तेज़ी से बैटरी खर्च होने की समस्या को कम करने और ऐप्लिकेशन की क्वालिटी बेहतर बनाने में डेवलपर की मदद करने की हमारी कोशिश का एक छोटा सा हिस्सा है.
वेक लॉक को समझकर और उन्हें सही तरीके से लागू करके, अपने ऐप्लिकेशन की बैटरी परफ़ॉर्मेंस को बेहतर बनाया जा सकता है. Google Play पर अपने ऐप्लिकेशन की सफलता पक्की करने के लिए, अन्य एपीआई का इस्तेमाल करना, वेक लॉक के सबसे सही तरीकों का पालन करना, और डीबग करने के असरदार टूल का इस्तेमाल करना ज़रूरी है. जैसे, Background Task Inspector, सिस्टम ट्रेस, और ProfilingManager.
-
प्रॉडक्ट से जुड़ी खबरेंGoogle Play पर, हमारा मकसद उपयोगकर्ताओं को सबसे अच्छा अनुभव देना है. साथ ही, यह पक्का करना है कि डेवलपर के पास सफल होने के लिए ज़रूरी टूल और अडैप्टेबिलिटी हो.
Paul Feng • पढ़ने में 3 मिनट लगेंगे -
प्रॉडक्ट से जुड़ी खबरेंपिछले साल, हमने Android डेवलपर की पहचान की पुष्टि करने की सुविधा शुरू की थी. इससे, इकोसिस्टम की सुरक्षा को मज़बूत किया जा सकता है और नुकसान पहुंचाने वाले ऐप्लिकेशन रिलीज़ करने के लिए, बुरे मकसद से काम करने वाले लोगों या ग्रुप को अपनी पहचान छिपाने से रोका जा सकता है.
Matthew Forsythe • पढ़ने में 2 मिनट लगेंगे -
प्रॉडक्ट से जुड़ी खबरेंऑगमेंटेड ओवरले से लेकर पूरी तरह से इमर्सिव एनवायरमेंट तक, Android XR का इकोसिस्टम तेज़ी से बढ़ रहा है. Samsung Galaxy XR आज से ही उपलब्ध है.
Stevan Silva, Vinny DaSilva • पढ़ने में 3 मिनट लगेंगे
Android डेवलपमेंट से जुड़ी नई अहम जानकारी, हर हफ़्ते अपने ईमेल में पाएं.