谷歌确认将限制Android非SDK接口使用了

2018 年 3 月 1 日 移动开发前线 核子可乐 译
译者|核子可乐
编辑|覃云
上个月,我们曾报道过  Android 9.0 将禁止使用非官方 API,引起了开发者的热烈的讨论,时隔一个多月,Android 团队终于发声证实了这个说法,声称从 Android 9.0 开始,对非 SDK 的 API 的限制从 NDK 扩展到 Java,并表明这样做的目的是为了提高系统的稳定性,接下来,我们来看看他们是怎么说的。
谷歌声明全文

在 Android 系统当中,我们一直在寻找各种方法以尽可能保证理想的稳定性,从而改善用户与开发人员体验。本着这一思路,我们努力确保应用程序不使用非 SDK 接口,因为此类作法往往会导致用户遭遇崩溃,并给开发人员的紧急发布造成困扰。

在 Android N 当中,我们限制了 C/C++ 代码所能使用的符号组合。此项变更确保使用 C++ 代码的应用程序能够始终对接稳定的 NDK 接口,而不会因依赖于不稳定的非 NDK 接口而引发崩溃机率提升。从 Android 的下一个版本开始,我们将进一步扩展此类限制,从而涵盖 SDK 的 Java 语言接口以进一步巩固稳定性水平。

  将带来哪些影响?

自 Android 的下一个版本开始,非 SDK 方法与字段的使用将受到限制,您将无法对其进行访问——无论通过直接、反射或者 JNI 等方式。如果加以尝试,您会看到 NoSuchFieldException 或者 NoSuchMethodException 等错误提示。

最初,此项限制主要涵盖使用率较低或并未得到实际使用的接口。我们在规划与设计工作当中,充分重新我们的开发者社区,并希望在解决用户及设备制造商所反馈的应用程序稳定性问题的同时,尽可能避免引入大幅度变更。如果您在实际开发当中存在一些能够迁移至 SDK 进行解决,但在技术层面存在挑战性的需求,我们将允许您继续使用原有方法,直到您逐步将应用程序更新至最新 API。

我们计划在未来的 Android 版本当中进一步扩大这些限制,为开发人员提供充分的迁移时间,同时长期发布警报通告,并在此期间收集与所需 SDK 接口相关的反馈意见。我们一直在强调使用非 SDK 接口的风险性影响——当我们重构代码以添加功能或修复 bug 时,使用非 SDK 接口可能在各类 Android 版本当中引发不可知的变化。因此,如果您的应用程序目前仍依赖于非 SDK 接口,则应尽快着手向 SDK 备选方案进行迁移。

由于 Java 语言与 C++ 在特性方面存在巨大差异,因此对 Java 语言的具体限制方式将与立足符号的 C++ 限制略有区别。您不应访问不属于我们 SDK 的类,同时亦需要确保仅使用各个类当中被纳入官方文档的部分。具体来讲,这意味着当您通过反射等语义与某个类进行交互时,所访问的方法或字段皆在 SDK 当中得以明确列出。

  如果缺少 SDK 替代选项,该如何处理?

我们知道,某些应用程序所使用的非 SDK 接口可能还找不到可行的 SDK 替代选项。我们非常重视您对于公共 API 扩展及改进方面提出的反馈意见。如果您确信在 SDK API 得到对应扩展之前无法停止使用非 SDK 接口,请通过我们的 bug 追踪器提供相关信息。及时获取这些反馈意见对我们来说非常重要,我们需要利用这部分资讯继续调整限制黑名单,从而最大限度降低此次迁移对开发人员的影响,同时着手为未来将陆续推出的各 Android 系统平台开发一切必要的替代方案。

  接下来将发生哪些变化?

在下一个 Android 开发者预览版当中,您将能够运行现有应用程序,并在使用非 SDK 接口时收到警告提示——该接口将在最终版本中受到黑名单或灰名单机制的限制。请确保您的应用在开发者预览版中始终遵循最佳实践 ; 另外,如果您担心自己的应用可能受到影响,请特别关注接口兼容性警告信息。

利用即将推出的开发者预览版与新的 bug 追踪器目录,我们将专注于监控非 SDK 接口的使用情况。如果相关接口已经拥有官方支持的 SDK 替代选项,我们将发布官方指南以帮助您了解如何从非 SDK 接口迁移至官方支持方案。

 移动开发前线

「移动开发前线」是 InfoQ 旗下关注移动开发技术的垂直社群。投稿请发邮件到 editors@cn.infoq.com,注明“移动开发前线投稿”。

  活动推荐

视频、3D、机器学习、算法工程化、IOT、智能硬件等新的命题正在被提出,丰富的内容生态以及内容形式在给传统开发的模式和线上的稳定性带来了新的挑战,而怪物级 APP 的移动开放生态也使得越来越多的移动开发者开始围绕着生态进行开发。QCon 北京 2018 会挑选部分话题来给大家分享,希望大家能够看到新移动技术的发展方向。

大会现 8 折报名中,看最佳理论和实践结合的体验,有任何问题欢迎咨询购票经理 Hanna,电话:15110019061,微信:qcon-0410。

登录查看更多
0

相关内容

SDK(Software Development Kit, 即软件开发工具包 )一般是一些被软件工程师用于为特定的软件包、软件框架、硬件平台、操作系统等建立应用软件的开发工具的集合。
FPGA加速系统开发工具设计:综述与实践
专知会员服务
65+阅读 · 2020年6月24日
【复旦大学-SP2020】NLP语言模型隐私泄漏风险
专知会员服务
24+阅读 · 2020年4月20日
【ICMR2020】持续健康状态接口事件检索
专知会员服务
17+阅读 · 2020年4月18日
【Google】利用AUTOML实现加速感知神经网络设计
专知会员服务
29+阅读 · 2020年3月5日
美团:基于跨平台框架Flutter的动态化平台建设
前端之巅
14+阅读 · 2019年6月17日
免费!Google Colab现已支持英伟达T4 GPU
新智元
5+阅读 · 2019年4月25日
使用 C# 和 Blazor 进行全栈开发
DotNet
6+阅读 · 2019年4月15日
从webview到flutter:详解iOS中的Web开发
前端之巅
5+阅读 · 2019年3月24日
Android P正式发布,你需要尽快做适配了
前端之巅
3+阅读 · 2018年8月7日
在浏览器中使用tensorflow.js进行人脸识别的JavaScript API
人工智能头条
6+阅读 · 2018年7月2日
Python3.7中一种懒加载的方式
Python程序员
3+阅读 · 2018年4月27日
免费云真机测试 | 让您的应用完美适配 Android Oreo
引力空间站
3+阅读 · 2018年2月2日
Arxiv
110+阅读 · 2020年2月5日
Arxiv
35+阅读 · 2019年11月7日
A Comprehensive Survey on Transfer Learning
Arxiv
121+阅读 · 2019年11月7日
Conceptualize and Infer User Needs in E-commerce
Arxiv
3+阅读 · 2019年10月8日
Arxiv
5+阅读 · 2019年8月22日
Arxiv
3+阅读 · 2017年12月18日
VIP会员
相关资讯
美团:基于跨平台框架Flutter的动态化平台建设
前端之巅
14+阅读 · 2019年6月17日
免费!Google Colab现已支持英伟达T4 GPU
新智元
5+阅读 · 2019年4月25日
使用 C# 和 Blazor 进行全栈开发
DotNet
6+阅读 · 2019年4月15日
从webview到flutter:详解iOS中的Web开发
前端之巅
5+阅读 · 2019年3月24日
Android P正式发布,你需要尽快做适配了
前端之巅
3+阅读 · 2018年8月7日
在浏览器中使用tensorflow.js进行人脸识别的JavaScript API
人工智能头条
6+阅读 · 2018年7月2日
Python3.7中一种懒加载的方式
Python程序员
3+阅读 · 2018年4月27日
免费云真机测试 | 让您的应用完美适配 Android Oreo
引力空间站
3+阅读 · 2018年2月2日
相关论文
Arxiv
110+阅读 · 2020年2月5日
Arxiv
35+阅读 · 2019年11月7日
A Comprehensive Survey on Transfer Learning
Arxiv
121+阅读 · 2019年11月7日
Conceptualize and Infer User Needs in E-commerce
Arxiv
3+阅读 · 2019年10月8日
Arxiv
5+阅读 · 2019年8月22日
Arxiv
3+阅读 · 2017年12月18日
Top
微信扫码咨询专知VIP会员