\

关键提要

\\

  • iOS的更新通常会在发布之后就能在所有受支持的设备上进行安装,然而Android的更新速度却慢得让人难以接受。\\t
  • Project Treble是试图解决这一系列问题(Android的碎片化)的尝试,它试图通过硬件抽象层(HAL,Hardware Abstraction Layer)对软硬件之间进行更明确的划分从而解决这一问题。\\t
  • 在Project Treble和Android Oreo之前,供应商的底层硬件代码和Google的AOSP操作系统(包括HAL)都是很庞大的。\\t
  • 由于集成了Project Treble,Google能够将最新版本的AOSP操作系统代码更新到设备,而OEM厂商则需要更新底层硬件相关的组件。\\t
  • Project Treble的关键是通过硬件定义语言(HIDL)、Android供应商测试套件(VTS,Vendor Test Suite)在HAL和它的用户之间定义一个清晰的接口。VTS是一组测试,用于验证升级后的操作系统与厂商硬件实现之间的兼容性。当前版本的Android中大约存在60种HIDL。\

\\

iOS的更新通常会在发布之后就能在所有受支持的设备上进行安装,然而Android的更新速度却慢得让人难以接受。事实上,Android智能手机能收到几次更新是很幸运的,因为现在智能手机的成本更低了,在它的整个生命周期中可能一次更新都收不到。

\\

众所周知,多年以来,碎片化已经成为Android世界的一个主要问题,为Android平台开发应用程序也变得更复杂了。缺乏安全性、日益增长的脆弱性以及不兼容性是Google、OEM厂商和用户的主要关注点。

\\

Project Treble是试图解决这一系列问题(Android的碎片化)的尝试。在对Project Treble进行介绍之前,理解硬件抽象层(HAL,Hardware Abstraction Layer)在Android OS框架中的作用能帮助你更好地理解Project Treble。

\\

硬件抽象层(HAL)

\\

硬件抽象层能够将其实现特性隐藏于更高级别的程序中,在此前提下使得操作系统与硬件设备进行通信。换句话说,HAL将硬件设备与操作系统分隔开来,如下图所示:

\\

\\

HAL是在Linux内核之下的一层,它用于处理HAL和设备硬件组件之间的特定硬件通信。不同于iOS设备,Android设备往往有许多不同的硬件组件,正因为如此,编译后的Linux二进制执行文件通常每个设备都是不同的。简单来说,这就是碎片化的问题所在。

\\

Project Treble前身

\\

在Project Treble和Android Oreo出现之前,供应商的底层硬件代码和Google的高级AOSP搞作系统(包括HAL)是非常庞大的。

\\

\\

也就是说,在Project Treble出现以前,为了更够让供应商升级到最新版本的Android系统,他们必须要对供应商的底层硬件代码和Google的高级AOSP操作系统进行更新,这一流程使得Android设备的升级被延迟,并将其置于安全风险中。

\\

\\

除此之外,手机制造商还需要等待硬件合作伙伴发布驱动更新,以确保硬件与最新版本的Android之间的兼容性。不同于Windows PC和Mac设备,Android并不是即插即用的。

\\

什么是Project Treble?Google想用它做什么?

\\

Android更新的主要问题在于,手机制造商迟迟不发布更新。更糟糕的是,随着新型号的到来,手机支持将会被重新进行评估。多年来,消费者一直在向手机制造商和Google表达不满。现在,Google的Project Treble的到来可能会改变手机制造商发布软件更新的方式。

\\

Project Treble是Android Oreo的一部分,它带来了操作系统框架的关键重构。这一项目的主要目标是使得Android系统的更新更快、更简单。Project Treble可能是Android Oreo系统更新中所宣布的最大的变化,但是消费者可能甚至都没有意识到这一点,因为这项改动并不是在手机的表面上。尽管如此,这一改动的好处依旧是不计其数。

\\

然而,你也不要把期望值定的太高,因为对设备的升级依然需要手机供应商的参与。

\\

Project Treble不同你想

\\

然而,与你想象的相反,Project Treble并不会将所有的Android Oreo设备都变成Pixel或Nexus。事实上,Google并不是自己来处理软件更新,Android设备制造商仍然需要将其编译并且进行发布。Project Treble是Google为了加速无线下载(OTA,over-the-air)更新所做的一项努力,但是发布OTA更新的职责依然属于供应商。OTA更新会和往常一样推送到你的设备上。如果Project Treble取得成功,你会更频繁地收到Android系统的更新通知。

\\

Project Treble为OS框架带来了哪些架构上的变化?

\\

Project Treble将Android操作系统框架从供应商的硬件代码实现中分离出来了。通过这一分离以及得益于Project Treble的集成,Google能够将更高级别的AOSP操作系统代码更新到最新版本,而由OEM厂商来对其底层硬件相关的组件进行更新。

\\

\\

但是,这并没有解决全部问题。OEM厂商仍然需要对其底层组件进行更新。并且他们还必须依赖于那些提供大部分硬件代码的SoC供应商们,这就违背了Project Treble的初衷。

\\

为了解决这一问题,Google已经找到了一种解决方案:使用HAL接口定义语言。它的目标是通过对细节进行抽象来减少对HAL的依赖。其余的部分依赖于供应商和OEM厂商。

\\

通过HIDL解决HAL问题

\\

正如我们前面所讨论的,HAL促进了硬件组件和应用程序之间的通信。Android O正式将HAL硬件组件进行了划分,比如音频或摄像头,以及操作系统层的客户端。这些新的正式的划分通过硬件定义语言(HIDL,Hardware Definition Language)来描述HAL和它的用户之间的接口。当前版本的Android中有大约60个不同的HIDL包。HIDL包可以在无需重新构建HAL的前提下替换操作系统框架,从而减少了供应商对Soc制造商的依赖,能够直接发布下一个OTA更新。这就意味着,无需重新编译HAL就能发布OTA更新,这样就可以迅速应用新版本的Android系统所带来的变化。

\\

\\

\\

当然了,等待升级到下一个版本的Android设备的硬件必须与这个版本的Android系统相兼容。在Project Treble发布以前,如果要发布软件更新,Android设备制造厂商需要依赖于电子制造商,而不用考虑当前设备的硬件与当前Android版本的兼容性。在之前,供应商的实现会受到新版本Android发布影响,其中包括半导体制造商(高通、联发科、三星等)的硬件专用代码,并且需要更新Android操作系统框架。随着Project Treble的发布,现在的情况已经不一样了。img

\\

\\

新的Android版本现在仅需要和被升级设备的未经改动的供应商实现部分进行兼容即可,升级过程可以通过Android供应商测试套件来确保顺利完成。Android供应商测试套件(VTS,Vendor Test Suite)是一组测试工具,它用于验证升级后的操作系统与供应商实现部分的兼容性。一旦兼容性测试通过,OEM厂商就可以通过升级OS框架的AOSP操作系统来发布一个OTA升级了。VTS是一款面向硬件的模拟兼容性测试套件(CTS,Compatibility Test Suite),它可以确保Android应用程序的API能够在Android设备上得以正确的实现。

\\

通过Android供应商测试套件(VTS)的测试对于Android设备来说是至关重要的,因为HIDL的目标是在不重新构建HAL的情况下替换操作系统框架。HAL是由半导体供应商进行构建的,并且构建于设备的供应商分区中,这使得操作系统框架被放置于一个自己的分区中,无需重新编译HAL就能够通过OTA更新进行替换。

\\

不论如何,更新AOSP操作系统是发布OTA更新的最低要求,但是大多数供应商都可以更新UI层,并且可以将他们自己的软件附加至更新中。这一过程需要时间。因此,不要指望Google将Android更新发布的几周内,Android升级就会出现在你的设备上,这一福利仍然只属于Pixel和Nexus设备。

\\

简而言之,尽管升级的方式还是保持不变,但是Project Treble已经消除了来自半导体供应商的依赖。

\\

反馈

\\

知名的在线出版社赞扬了Project Treble,因为它消除了Android生态系统中最大的问题之一,包括以下内容:

\\

  • Time杂志写道,Android Oreo的这一新特性能够解决Google的一个大麻烦。\\t
  • Techradar称Project Treble为Android史上最重要的更新。\\t
  • XDA论坛的Mishaal Rahmaan称其为自定义ROM的一场革命,因为Project Treble使得Android Oreo变得极其容易。\\t
  • Andy Rubin的Essential Phone、华为、华硕等都在将其设备升级至Android Oreo时表示了对Project Treble的支持。\

然而,许多手机制造商在将他们的设备升级到Android Oreo时并没有提供对Project Treble的支持。似乎许多Android设备制造商对Project Treble带来的操作系统框架的架构性改动感到担忧,链接中的这些设备在升级到Android Oreo时提供对Project Treble的支持。

\\

为什么有一些OEM厂商选择退出?

\\

OEM厂商对Project Treble的顾虑

\\

对于Android厂商来说,将其设备升级从Nougat升级至Oreo时,Project Treble这一特性的改动尤其让人担忧。一名OnePlus员工在AMA会议上给出了担忧背后的合理的理由:

\\

\

Project Treble需要一个存储分区,通过该分区将Android框架和供应商的映像相分离。但是,由于Android N和之前的Android版本并不需要这一份去,因此我们现在的所有设备都没有该分区。根据我们的测试,如果我们通过OTA升级来修改分区布局,那么在进行分区的时候,设备有可能会变砖。我们认为这对于我们的用户来说是一个很大的风险,这就是我们为什么决定不在当前的OnePlus设备上添加Project Treble支持的原因。

\

\\

中国智能手机品牌OnePlus是首家在Android平台上退出Project Treble功能的厂商,该公司目前当前和之前的旗舰设备都是基于Android Nougat系统的。

\\

Nokia是第二家对Project Treble向公众发布犹豫不决的公司,尤其是在将当前设备升级到支持Project Treble的Android Oreo的时候:

\\

\

在将来,HMD会致力于在所有新的Android Oreo设备上实现Project Treble,我们对可能导致的用户的失望表示道歉。

\

\\

最后的一点想法

\\

对于Android应用程序开发者和用户来说,这的确是一个伟大的时刻,因此Google终于解决了它的一大烦恼,即统一操作系统。Project Treble意味着手机将拥有更长的支持周期,而不是仅仅两年,两年是目前大多数旗舰公司所提供的支持周期。但是,最终这还将取决于OEM厂商是否会对其设备发布更新的决定。

\\

关于作者

\\

Shahid Mansuri 是Peerbits的联合创始人,Peerbits是美国领先的Android移动应用程序开发公司,成立于2011年。他的远见卓识和张扬的管理风格给公司带来了丰硕的成果。他相信,在创业上和商业上,他会把自己的知识基础与自己的知识不断地进行分享。作为一个热爱大自然的人,他喜欢在假期的时候在海滩上展示他的睡衣。

\\

查看英文原文:Is Project Treble the Answer to Android Updates?

Project Treble是Android升级的最终方案吗?相关推荐

  1. android treble 三星,三星S8/Note8升Android 8.0后 确认不支持Project Treble特性

    目前各大国产智能手机厂商已开始准备升级Android 8.0,进行内部测试,明年将会有一大波手机可以用上Android 8.0.现在最新消息,有用户三星S8/Note8手机升Android 8.0后, ...

  2. android treble 三星,遗憾!Project Treble这么好,三星旗舰却不支持!

    近来,许多安卓厂商都开始向他们的旗舰手机推送安卓8.0的系统更新,安卓8.0的一个亮眼特性就是Project Treble,支持Project Treble特性的机型以后在升级安卓系统的时候厂商适配的 ...

  3. 平板升级android版本号,App版本升级方案

    App版本升级方案小结 方案一:后端处理逻辑 - 通过指定数字版本号判断 app/ipad升级 入参数: appid app应用类型:1.A商城android app.2.A商城android ipa ...

  4. Android Art Hook 技术方案

    Android Art Hook 技术方案 by 低端码农 at 2015.4.13 www.im-boy.net 0x1 开始 Anddroid上的ART从5.0之后变成默认的选择,可见ART的重要 ...

  5. Android推送集成方案总结

    Android推送集成方案总结 刚做完推送集成方案,记录下坑. 这里记录的特性和使用时针对写blog时采用的sdk的,具体使用流程和限制还请参考官方给出的sdk. 1.推送规则 小米手机用小米推送: ...

  6. Android 双u盘方案

     1      L1813系统上双U盘设计方案--系统设计 1.1     方案背景 Android原生的磁盘管理方案,设计的思想是将EMMC上的空间通过sdcard的server模拟成一个Sto ...

  7. 【转载】Android微信智能心跳方案

    PS: 原文链接为: [Android微信智能心跳方案],作者为 微信团队的 phoenix 这里转载,主要是为了学习这个智能心跳方案,并实践之. 前言:在13年11月中旬时,因为基础组件组人手紧张, ...

  8. Android网络连接异常处理方案

    Android网络连接异常处理方案 参考文章: (1)Android网络连接异常处理方案 (2)https://www.cnblogs.com/yangcong/p/3523021.html 备忘一下 ...

  9. Android Webview H5 秒开方案实现

    本文首发于微信公众号「玉刚说」 原文链接:Android Webview H5 秒开方案实现 前言 现在许多app都嵌入了H5页面, 然而WebView加载速度慢这个问题却一直影响着用户的体验, 所以 ...

最新文章

  1. input(position 1) must be Tensor, not NoneType
  2. linux虚拟网络设备--虚拟机网卡和linux bridge上tap设备的关系(七)
  3. docker网络配置方法总结
  4. 剑指Offer——斐波那契数列
  5. 多线程——线程的生命周期
  6. android 开源 数据库,Android开源数据库框架-LitePal的使用
  7. 内推 | 字节跳动算法提前批
  8. Unity+SenseAR教程:用手势发射爱心【源码】
  9. 四面体的表面积_边长为正四面体的表面积是()、;、;、;、。
  10. 投放Facebook广告,跑到爆品之后怎样扩量效果更好?
  11. 浙江3 2计算机学校,浙江有那些3+2学校
  12. python下int转日期_减去不同格式的日期并转换为Int - python
  13. 蓝桥杯2016年第七届C/C++省赛B组第四题-快速排序
  14. 【转】opengl的一些小问题
  15. 经典散文集锦:读者杂志卷首语大荟萃
  16. 使用stm32f103rct6控制adf4351实现30M~~4G的正弦波
  17. 前端对接钉钉的步骤以及代码
  18. macOS 虚拟摄像头:CamTwist for Mac
  19. Hibernate 缓存机制续 - 查询缓存
  20. 凯文凯利 《必然》 读书笔记

热门文章

  1. 如何用PS把图片中的人物剪掉
  2. 测试固态参数的软件,BT测试告诉你 SSD 那些性能参数最重要
  3. 效率系列(二) Win10常用快捷键
  4. 用速腾16线激光雷达跑gmapping
  5. arduino低功耗模式_一起来看看新推出的Arduino开发板MKR WAN 1310
  6. 平头哥智能语音CB5654开发板如何读取云端的返回值
  7. 反积分饱和 程序_三面大疆惨败,因为不懂PID的积分抗饱和
  8. Android图片压缩框架汇总分析
  9. 蓝桥杯第七届省赛JavaB组题解
  10. 2023首届大学生算法大赛——补题