مدیریت نیرو

اندروید 9 (سطح API 28) ویژگی های جدیدی را برای بهبود مدیریت انرژی دستگاه معرفی می کند. این تغییرات، همراه با ویژگی‌هایی که قبلاً در نسخه‌های قبلی وجود داشت، کمک می‌کند تا اطمینان حاصل شود که منابع سیستم در اختیار برنامه‌هایی قرار می‌گیرد که بیشتر به آنها نیاز دارند.

ویژگی های مدیریت قدرت به دو دسته تقسیم می شوند:

سطل های آماده به کار برنامه
این سیستم دسترسی برنامه ها را به منابع دستگاه مانند CPU یا باتری بر اساس الگوهای استفاده کاربر محدود می کند. این یک ویژگی جدید برای اندروید 9 است.
بهبود صرفه جویی در باتری
وقتی بهینه‌سازی باتری روشن است، سیستم محدودیت‌هایی را برای همه برنامه‌ها اعمال می‌کند. این یک ویژگی موجود است که با اندروید 9 بهبود یافته است.

سطل های آماده به کار برنامه

اندروید 9 یک ویژگی جدید مدیریت باتری، App Standby Buckets را معرفی می کند. App Standby Buckets به سیستم کمک می‌کند تا درخواست‌های برنامه‌ها برای منابع را براساس میزان اخیر و تعداد دفعات استفاده از برنامه‌ها اولویت‌بندی کند. بر اساس الگوهای استفاده از برنامه، هر برنامه در یکی از پنج سطل اولویت قرار می گیرد. این سیستم منابع دستگاه در دسترس برای هر برنامه را بر اساس سطل برنامه محدود می کند.

این پنج سطل برنامه‌ها را با ویژگی‌های زیر به گروه‌هایی اولویت‌بندی می‌کنند:

فعال

اگر کاربر در حال حاضر از برنامه استفاده می کند، یک برنامه در سطل فعال است، به عنوان مثال:

  • برنامه فعالیتی را راه اندازی کرده است
  • این برنامه یک سرویس پیش زمینه را اجرا می کند
  • این برنامه دارای یک آداپتور همگام سازی مرتبط با ارائه دهنده محتوا است که توسط یک برنامه پیش زمینه استفاده می شود
  • کاربر روی یک اعلان از برنامه کلیک می کند

اگر برنامه‌ای در سطل فعال باشد، سیستم هیچ محدودیتی برای کارهای برنامه، آلارم‌ها یا پیام‌های FCM قائل نمی‌شود.

مجموعه کاری

اگر یک برنامه اغلب اجرا شود اما در حال حاضر فعال نیست، در سطل مجموعه کار قرار دارد. به عنوان مثال، یک برنامه رسانه اجتماعی که کاربر بیشتر روزها راه اندازی می کند، احتمالاً در مجموعه کار قرار دارد. اگر برنامه‌ها به‌طور غیرمستقیم استفاده شوند، به سطل مجموعه کار ارتقا می‌یابند.

اگر برنامه‌ای در مجموعه کار باشد، سیستم محدودیت‌های ملایمی را بر توانایی آن برای اجرای کارها و راه‌اندازی آلارم اعمال می‌کند. برای جزئیات، به محدودیت‌های مدیریت نیرو مراجعه کنید.

مکرر

اگر یک برنامه به طور منظم استفاده شود، اما نه لزوماً هر روز، در سطل مکرر قرار می گیرد. به عنوان مثال، یک برنامه ردیابی تمرین که کاربر در باشگاه اجرا می کند ممکن است در سطل مکرر باشد.

اگر یک برنامه در سطل مکرر قرار داشته باشد، سیستم محدودیت‌های قوی‌تری بر توانایی آن برای اجرای کارها و راه‌اندازی آلارم‌ها اعمال می‌کند، و همچنین محدودیتی بر پیام‌های FCM با اولویت بالا اعمال می‌کند. برای جزئیات، به محدودیت‌های مدیریت نیرو مراجعه کنید.

نادر

اگر یک برنامه اغلب استفاده نشود، در سطل کمیاب قرار دارد. به عنوان مثال، یک برنامه هتل که کاربر فقط در زمانی که در آن هتل اقامت دارد اجرا می کند ممکن است در سطل کمیاب باشد.

اگر برنامه‌ای در سطل کمیاب باشد، سیستم محدودیت‌های سختی بر توانایی آن برای اجرای کارها، راه‌اندازی آلارم‌ها و دریافت پیام‌های FCM با اولویت بالا اعمال می‌کند. این سیستم همچنین توانایی برنامه برای اتصال به اینترنت را محدود می کند. برای جزئیات، به محدودیت‌های مدیریت نیرو مراجعه کنید.

هرگز

برنامه هایی که نصب شده اند اما هرگز اجرا نمی شوند به سطل never اختصاص داده می شوند. این سیستم محدودیت های شدیدی را برای این برنامه ها اعمال می کند.

سیستم به صورت پویا هر برنامه را به یک سطل اولویت اختصاص می دهد و برنامه ها را در صورت نیاز مجدداً اختصاص می دهد. این سیستم ممکن است به یک برنامه از پیش بارگذاری شده متکی باشد که از یادگیری ماشین برای تعیین میزان احتمال استفاده از هر برنامه استفاده می کند و برنامه ها را به سطل های مناسب اختصاص می دهد. اگر برنامه سیستم در دستگاهی موجود نباشد، سیستم به طور پیش‌فرض برنامه‌ها را بر اساس اخیراً استفاده شده مرتب می‌کند. برنامه‌های فعال‌تر به سطل‌هایی اختصاص داده می‌شوند که به برنامه‌ها اولویت بیشتری می‌دهند و منابع سیستم بیشتری را در اختیار برنامه قرار می‌دهند. به طور خاص، سطل تعیین می‌کند که کارهای برنامه چند بار اجرا شود، هر چند وقت یک‌بار برنامه می‌تواند آلارم‌ها را راه‌اندازی کند، و هر چند وقت یک‌بار برنامه می‌تواند پیام‌های Firebase Cloud Messaging (FCM) با اولویت بالا را دریافت کند. این محدودیت‌ها فقط زمانی اعمال می‌شوند که دستگاه از باتری استفاده می‌کند. هنگامی که دستگاه در حال شارژ شدن است، سیستم این محدودیت ها را بر روی برنامه ها اعمال نمی کند.

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

بهترین شیوه ها

اگر برنامه شما در حال حاضر بهترین روش‌ها را برای Doze و آماده به کار برنامه دنبال می‌کند، مدیریت ویژگی‌های جدید مدیریت انرژی نباید دشوار باشد. با این حال، برخی از رفتارهای برنامه که قبلاً به خوبی کار می کردند اکنون ممکن است مشکلاتی ایجاد کنند.

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

    توجه: اگر کاربر مکرراً یک اعلان را رد کند، سیستم به کاربر این امکان را می دهد که آن اعلان را در آینده مسدود کند. فقط برای اینکه سعی کنید برنامه خود را در سطل فعال نگه دارید، کاربر را با اعلان ها اسپم نکنید!

  • اگر برنامه‌ها در چندین بسته تقسیم شوند، آن بسته‌ها ممکن است در سطل‌های مختلف باشند و بنابراین سطوح دسترسی متفاوتی داشته باشند. باید مطمئن شوید که چنین برنامه هایی را با بسته های اختصاص داده شده به سطل های مختلف آزمایش کنید تا مطمئن شوید برنامه به درستی عمل می کند.

بهبود صرفه جویی در باتری

اندروید 9 تعدادی بهبود در حالت صرفه جویی در باتری ایجاد می کند. سازنده دستگاه محدودیت های دقیق اعمال شده را تعیین می کند. به عنوان مثال، در ساخت‌های AOSP، سیستم محدودیت‌های زیر را اعمال می‌کند:

  • این سیستم برنامه‌ها را به‌جای اینکه منتظر بماند تا برنامه بی‌حرکت باشد، با شدت بیشتری در حالت آماده به کار برنامه قرار می‌دهد.
  • محدودیت های اجرای پس زمینه برای همه برنامه ها، صرف نظر از سطح API هدف آنها اعمال می شود.
  • خدمات مکان ممکن است زمانی که صفحه خاموش است غیرفعال شود.
  • برنامه های پس زمینه دسترسی به شبکه ندارند.

علاوه بر این، بهینه‌سازی‌های قدرت خاص دستگاه دیگری نیز وجود دارد. برای جزئیات کامل، به صفحه ای که محدودیت های مدیریت انرژی را توضیح می دهد مراجعه کنید.

مثل همیشه، ایده خوبی است که برنامه خود را تا زمانی که بهینه ساز باتری فعال است، آزمایش کنید. می‌توانید از طریق تنظیمات > صفحه نمایش «بهینه‌سازی باتری» دستگاه، «بهینه‌سازی باتری» را به صورت دستی روشن کنید.

تست و عیب یابی

ویژگی‌های جدید مدیریت انرژی بر همه برنامه‌های در حال اجرا در دستگاه‌های Android 9 تأثیر می‌گذارد، چه برنامه‌ها Android 9 را هدف قرار دهند یا نه. مهم است که مطمئن شوید برنامه شما در این دستگاه‌ها به درستی عمل می‌کند.

حتماً موارد استفاده اصلی برنامه خود را تحت شرایط مختلف آزمایش کنید تا ببینید چگونه ویژگی‌های مدیریت انرژی با یکدیگر تعامل دارند. می‌توانید از دستورات Android Debug Bridge برای روشن و خاموش کردن برخی از ویژگی‌ها استفاده کنید.

دستورات Android Debug Bridge

می توانید از دستورات پوسته Debug Bridge Android برای آزمایش چندین ویژگی مدیریت انرژی استفاده کنید.

برای اطلاعات در مورد استفاده از ADB برای قرار دادن دستگاه خود در Doze، به تست با Doze و App Standby مراجعه کنید.

سطل های آماده به کار برنامه

می توانید از ADB برای اختصاص دستی برنامه خود به یک App Standby Bucket استفاده کنید. برای تغییر سطل برنامه از دستور زیر استفاده کنید:

$ adb shell am set-standby-bucket packagename active|working_set|frequent|rare

همچنین می توانید از این دستور برای تنظیم چندین بسته به طور همزمان استفاده کنید:

$ adb shell am set-standby-bucket package1 bucket1 package2 bucket2...

برای بررسی اینکه یک برنامه در چه سطلی قرار دارد، اجرا کنید

$ adb shell am get-standby-bucket [packagename]

اگر پارامتر packagename ارسال نکنید، دستور سطل‌های همه برنامه‌ها را فهرست می‌کند. یک برنامه همچنین می‌تواند با فراخوانی روش جدید UsageStatsManager.getAppStandbyBucket() در زمان اجرا، سطل خود را پیدا کند.

صرفه جویی در باتری

چندین دستور برای آزمایش نحوه عملکرد برنامه شما در شرایط کم مصرف وجود دارد.

برای شبیه سازی دستگاه در حال جدا شدن از برق، از دستور استفاده کنید

$ adb shell dumpsys battery unplug

برای آزمایش نحوه عملکرد دستگاه در شرایط کم مصرف، از این دستور استفاده کنید:

$ adb shell settings put global low_power 1

هنگامی که آزمایش خود را به پایان رساندید، می توانید تنظیمات دستی دستگاه خود را با این دستور لغو کنید:

$ adb shell dumpsys battery reset