在很長一段時間裡Android用戶批評iOS積極殺死在後臺運行的應用程序的方式。Android手機的多任務處理能力、更大的內存池和更大的電池被作為該平臺優越性的例子四處宣揚。然而因為種種原因,一些制造商已經自行采取瞭更嚴格的措施,甚至可能違背瞭Google的政策,Google現在想知道這些OEM廠商是誰。
調查表格:
https://docs.google.com/forms/d/e/1FAIpQLSd9P3gLKgMbVwQnAra6UhOjnCWtKpp55kYmigUKo8-ynmvdPg/viewform?resourcekey=0-e65sRbpisoGmtEe_zPZnMg
大多數Android應用可能不需要總是在後臺運行,但肯定有一類應用需要。事實上,有一類應用根本就不應該在後臺運行,特別是那些意圖不純的應用,如惡意軟件。然而,一些以健康為中心的應用程序可能需要一直運行,但系統可能不會總是讓這些應用程序運行。
當然,後臺應用程序雖然帶來瞭不少便利,但也不是沒有代價的,通常是在CPU占用和最終帶來的電池續航表現縮短方面。這就是為什麼包括Android在內的平臺對哪些應用程序可以這樣做以及何時這麼做設定瞭規則和限制。Android系統也為例外情況留出瞭空間,並提供瞭支持應用程序進入睡眠狀態並再次喚醒的方法。
另一方面,Google也為OEM廠商制定瞭規則,使其在後臺殺應用程序進程的過程透明化,但這就是事情變得有點混亂的地方。一些原始設備制造商在Android系統的基礎上實施他們自己的應用程序殺進程政策,但通常不會讓開發者、更不會讓用戶知道這些。具體就會表現在一些應用程序,如睡眠監測或活動跟蹤應用程序可以在一個手機上運行,在另一個品牌上可能無法正常工作,隻是因為後者更積極地殺死瞭在後臺運行的應用程序。
多年來,應用程序開發人員一直在抱怨這種情況,似乎Google終於聽到瞭他們的請求。有人報告說某些品牌甚至扼殺瞭重要的Android可訪問性輔助服務(這被視為照顧視障聽障人士等弱勢群體的操作系統基本功能)。早在2018年,AOSP錯誤跟蹤器就創建瞭一個問題,詳細說明瞭一部分OEM廠商是如何濫用Android的核心功能,禁止第三方應用程序在後臺運行。這個問題充滿瞭數百名應用開發者的回應,呼應瞭類似的經歷,敦促Google阻止OEM廠商違反Android系統的合規性,實施如此激進的政策。
2021年6月8日,一位用戶評論說,小米和一加等OEM廠商甚至殺死瞭AccessibilityService。作為回應,一名Google員工最近評論說,他們將研究這個問題,並邀請應用程序開發人員提交他們的反饋。
Google要求開發者提供以下細節:
受影響的應用程序的名稱
他們觀察到問題的OEM和設備型號的名稱
Android操作系統版本
重現該問題的步驟,以及預期結果和觀察到的結果
受影響的API
他們是否能夠在Pixel設備(或其他運行相同Android版本的設備)上重現相同的問題。
考慮到這種情況已經持續瞭多年,這項調查真的是姍姍來遲。正如他們所說,遲到總比不到好。Google甚至不需要親自詢問開發者,因為 "Don’t Kill My App"網站也已經存在多年瞭,想要從苦手機廠商者久矣的程序員中獲得事實情況並不算困難。
Android資料庫中有關電源管理的章節:
https://developer.android.com/about/versions/pie/power
Android開發社區中投訴OEM廠商殺進程的錯誤跟蹤頁面:
https://issuetracker.google.com/issues/122098785?pli=1#comment155
留言列表