草庐IT

32位应用已经凉了!

路遥 2023-03-28 原文
作者 | 路遥

审校 | 云昭

近日,Google正式发布了Android 13,并率先向Pixel设备推送了系统更新。

然而没过多久,就有爆料人士在Android 13的代码仓库中发现,Google提交了“Move tangor to 64-bit only”(翻译为“仅将tangor移动到64位”)。其中“tangor”为Pixel平板的代号,根据这个信息,似乎意味着Pixel平板或将仅支持64位的Android应用。

与此同时,爆料者还发现了另一个提交的信息,其中表明在安装了Android U(Android 14) 或更高版本上的设备上无法运行32位应用的字样。

也就是说,从明年开始,Android将放弃支持32位应用,支持64位可能会成为一个常规功能。

此话题在51CTO技术社群里也引发了热烈讨论。群友【王行】:32位被抛弃已经是时代发展的必然,实际上现行的ARM v8 64位指令集已经是10年前的产物,就智能手机来说只要是在差不多2014年后上市的主流机型,所使用的CPU架构、指令集其实都已经是针对64位环境设计的了。作为工程师可以趁着更新32位的这个“机会”走鸿蒙的一条路。

群友【周佳怡】:虽然放弃了32位,但是对于64位,谷歌提供了不同的工具和大量文档,让应用程序开发人员为切换到64位做好准备。对于许多应用程序,实际上几乎没有什么可做的,因为那些用Java或Kotlin编写的应用程序不需要更改。但是使用游戏引擎或第三方SDK开发的应用程序需要确保使用最新的64位版本。性能上确实挺提高了很多,开发者需要了解数据类型和数据转换都发生了变化,以及结构的对齐也发生了变化。

群友【荣先钊】:32位采用固有架构,限制了系统的发展,部分应用可能要重新做适配开发吧

群友【向阳而生】:向64位的迁移有助于减少RAM占用、减少存储空间占用以及提高底层安全水平。另外,ARM全新的Cortex A65架构已经是纯64位CPU,删除了32位指令集,不管对用户还是行业,都算是好事。

那么32位和64位到底有什么不同?强制升级到底有没有必要?

1.64位的优势 

我们平常使用手机和电脑,所操作的内容在处理器上通常都是以数字表示,而处理器会以二进制的形式来储存这些数字,为它们分配的空间会以位为单位。

而位则是指一次性可处理的数据量是多少,1字节等于8位,那么算下来,32位就是一次性可以处理处理4个字节的数据量,而64位就是一次性处理8个字节的数据量,理论上处理效率快了一倍。

不好理解,换一种说法。32位好比是3车道,而64位就好比是升级到了6车道,通行效率提升了一倍,尤其是高峰使用时效率更高,资源分配更合理,这个提升可是非常明显。

与此同时,在寻址空间上也有比较明显的差距,32位处理器可以访问2的32次方个内存地址,最高支持4GB的运行内存,而64位处理器可以访问2的64次方个内存地址,理论上可以支持大约16TB的运行内存。但这只是理论上,由于不同架构的CPU设计不同,所以能力也有差别。随着硬件、软件的高速发展,4GB运存早已无法满足某些软件的使用需求,打个比方,现在手机的运行内存基本都是6GB、8GB甚至是12GB,如果配备了32位的处理器,那么就会有部分内存被浪费,甚至还会影响到运行效能,好马配好鞍,朝着64位升级就是刚需。

以骁龙 8 Gen 1和天玑9000为例,这两枚芯片都采用了ARMv9架构方案,带来了三款CPU:Cortex-X2超大核、Cortex-A710大核和Cortex-A510小核。

其中骁龙 8 Gen 1就采用了3个2.5GHz的Cortex-A710大核、1个3.0GHz的Cortex-X2超大核和4个1.8GHz的Cortex-A510小核。

但这8个核当中只有Cortex-A710能够兼容32位应用,Cortex-X2和Cortex-A510仅支持64位操作系统及应用程序。

这也就是说在运行32位应用时,只能用到其中的3个核,其他5个核只能处于停工状态,这样一来运行速度和效率就会大打折扣,严重一点可能还会出现增加功耗、应用闪退等问题。至于32位到64位有多大的提升,联发科公布了对比测试,证实64位应用无论是在应用的冷启动速度还是能耗、游戏性能等方面都有显著的提升。

图源:MediaTek实验室

总而言之,32位应用+64位处理器,非常影响运行效率,只有64位处理器+64位应用结合在一起,才能让运行效率大幅度提升。

2.64位生态推进缓慢 

正因为64位是趋势,所以早在2013年,苹果在iPhone 5s上搭载的A7处理器就是使用的是64位。

对比之前的A6的性能提升将近2倍,这次升级也让苹果在移动领域直接领先了同期的竞争对手。

紧接着,安卓阵营也开始积极朝着64位升级。高通第一款64位处理器骁龙410在同年年底发布,到了2014年,谷歌推出首个支持64位的安卓系统Android L。而苹果这边到了2015年,就已经开始要求iOS新上架的应用必须支持64位。

但由于当时政策、生态环境等多方面的影响,虽然支持64位,但依旧可以向下兼容32位,这就导致很多开发者不愿再动刀向64位迁移,于是64位处理器的优势完全发挥不出来,同时生态也变得非常混乱。

面对这些问题,最先狠下心的是苹果。

在2017年的iOS 11系统上就明确表示,将不再支持32位应用。

而安卓这边,一直没能下狠心动刀。

在2019年,谷歌曾就要求上架到Play Store的应用,除了提供32位版本外,还必须提供64位版本,到了2021年,宣布不再允许64位设备下载32位应用,但依旧“心软”没说强行禁止,而是可以兼容使用,甚至在自家Chrome浏览器的下载页面也提供32位选择。

图源于网路

究其缘由可能还是开发、运维成本的问题,如果开发者只开发32位应用,那么应用完全可以运行在64位处理器上的,但如果开发64位应用,那么一些旧机型就无法运行,后续的维护成本也是问题,所以很多开发者只能选择损失运行效率来保住“饭碗”。直到2021年,ARM终于宣布,从2023年开始,Arm架构CPU内核将强制采用64位,且没有32位兼容模式。可能正是基于这个原因,各大手机厂商们也开始积极响应。

华为开发者联盟的邮件称,华为应用市场到2022年9月1日之前将分阶段淘汰32位应用,目的是为了更好地提升应用性能体验、降低应用的功耗影响。

随后,移动智能终端生态联盟宣布,从2022年4月起,在联盟成员OPPO、vivo、 小米应用商店新上架应用不允许单独上架32位应用包,必须要提供64位版本的安装包。

图源:微博@移动智能终端生态联盟

随着政策的颁布,强制不支持32位可能暂时会对部分应用和用户体验上造成影响,但从长期来看,这绝对是一件好事。

一方面,32位应用运行在64位处理器上,性能可能无法完全得不到发挥,反而会造成前面说的卡顿、增加功耗等问题,只有升级到64位才能缓解这些问题。另一方面,由于32位应用可能无法做到按照新的指南实时更新,一些新功能就无法正常使用,同时安全性也无从保障。

3.写在最后 

现在应用的安装包越来越大,所消耗的内存、运存也越来越多,同时对于系统和处理器的性能要求也越来越高。采用64位处理器可以保证在处理视频、游戏、解码等操作下,更充分的调动移动设备的性能,减少不必要的效能损耗。同时不再支持32位也可以保证软件的流畅运行。无论从哪个方面来说,对于用户的影响都是积极地。但即便是政策出台和系统限制,也依旧无法解决安卓生态混乱的问题,归根到底,还是需要一些更有力的措施,才能让安卓生态良性健康的发展。

参考链接:

https://baijiahao.baidu.com/s?id=1729417473150023472&wfr=spider&for=pc

http://app.myzaker.com/news/article.php?pk=60c856858e9f0977a82fd340&f=zaker_live

有关32位应用已经凉了!的更多相关文章

  1. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  2. ruby-on-rails - Rails 应用程序之间的通信 - 2

    我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此

  3. ruby - 无法运行 Rails 2.x 应用程序 - 2

    我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby​​:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r

  4. ruby-on-rails - Rails 应用程序中的 Rails : How are you using application_controller. rb 是新手吗? - 2

    刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr

  5. ruby-on-rails - 如何在我的 Rails 应用程序 View 中打印 ruby​​ 变量的内容? - 2

    我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby​​中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R

  6. ruby-on-rails - 如何在 Gem 中获取 Rails 应用程序的根目录 - 2

    是否可以在应用程序中包含的gem代码中知道应用程序的Rails文件系统根目录?这是gem来源的示例:moduleMyGemdefself.included(base)putsRails.root#returnnilendendActionController::Base.send:include,MyGem谢谢,抱歉我的英语不好 最佳答案 我发现解决类似问题的解决方案是使用railtie初始化程序包含我的模块。所以,在你的/lib/mygem/railtie.rbmoduleMyGemclassRailtie使用此代码,您的模块将在

  7. 世界前沿3D开发引擎HOOPS全面讲解——集3D数据读取、3D图形渲染、3D数据发布于一体的全新3D应用开发工具 - 2

    无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD

  8. 叮咚买菜基于 Apache Doris 统一 OLAP 引擎的应用实践 - 2

    导读:随着叮咚买菜业务的发展,不同的业务场景对数据分析提出了不同的需求,他们希望引入一款实时OLAP数据库,构建一个灵活的多维实时查询和分析的平台,统一数据的接入和查询方案,解决各业务线对数据高效实时查询和精细化运营的需求。经过调研选型,最终引入ApacheDoris作为最终的OLAP分析引擎,Doris作为核心的OLAP引擎支持复杂地分析操作、提供多维的数据视图,在叮咚买菜数十个业务场景中广泛应用。作者|叮咚买菜资深数据工程师韩青叮咚买菜创立于2017年5月,是一家专注美好食物的创业公司。叮咚买菜专注吃的事业,为满足更多人“想吃什么”而努力,通过美好食材的供应、美好滋味的开发以及美食品牌的孵

  9. 【鸿蒙应用开发系列】- 获取系统设备信息以及版本API兼容调用方式 - 2

    在应用开发中,有时候我们需要获取系统的设备信息,用于数据上报和行为分析。那在鸿蒙系统中,我们应该怎么去获取设备的系统信息呢,比如说获取手机的系统版本号、手机的制造商、手机型号等数据。1、获取方式这里分为两种情况,一种是设备信息的获取,一种是系统信息的获取。1.1、获取设备信息获取设备信息,鸿蒙的SDK包为我们提供了DeviceInfo类,通过该类的一些静态方法,可以获取设备信息,DeviceInfo类的包路径为:ohos.system.DeviceInfo.具体的方法如下:ModifierandTypeMethodDescriptionstatic StringgetAbiList​()Obt

  10. ruby-on-rails - 从应用程序中自定义文件夹内的命名空间自动加载 - 2

    我们目前正在为ROR3.2开发自定义cms引擎。在这个过程中,我们希望成为我们的rails应用程序中的一等公民的几个类类型起源,这意味着它们应该驻留在应用程序的app文件夹下,它是插件。目前我们有以下类型:数据源数据类型查看我在app文件夹下创建了多个目录来保存这些:应用/数据源应用/数据类型应用/View更多类型将随之而来,我有点担心应用程序文件夹被这么多目录污染。因此,我想将它们移动到一个子目录/模块中,该子目录/模块包含cms定义的所有类型。所有类都应位于MyCms命名空间内,目录布局应如下所示:应用程序/my_cms/data_source应用程序/my_cms/data_ty

随机推荐