Google正调查手机厂商在杀Android后台进程时过于激进的问题
Google正调查手机厂商在杀Android后台进程时过于激进的问题
在过去的几年里,Google 已经大大改善了 Android 系统处理后台应用程序的方式。Doze 和 App Standby Buckets 等优化措施有助于将系统资源分配给最需要的应用程序,同时确保滥用的应用程序不会在后台肆意运行。
在很长一段时间里 Android 用户批评 iOS 积极杀死在后台运行的应用程序的方式。Android 手机的多任务处理能力、更大的内存池和更大的电池被作为该平台优越性的例子四处宣扬。然而因为种种原因,一些制造商已经自行采取了更严格的措施,甚至可能违背了 Google 的政策,Google 现在想知道这些 OEM 厂商是谁。
调查表格:
大多数 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
来自: cnBeta