鸿蒙体系扫盲(五):再谈鸿蒙开辟用什么语言?
前段时间,发表了鸿蒙体系扫盲(三):鸿蒙开辟用什么语言?这篇文章,收到一些网友的提问,一一解答了,还有网友对我举行了严肃的品评和锋利的责怪,说我有点颠倒是非,ts的是脚本语言,Java是编译语言,我说ts的性能凌驾Java,是来搞笑的。本着严谨学习的态度,我查阅了大量的资料,也向一些大神请教了,以为有必要再深入,全面但用不要故作高深地、通俗易懂地拓展一下这方面的知识,这是一个开放交换的平台,假如有错误之处,盼望大家指出来,一起学习进步!
1.Java是解释型语言还是编译型语言?
首先看一个事例:假如你是一个交际官,你要出访一个国家A,但是你不会A国的语言,这时候你就必须带一个翻译官,你说一句中文,他就会给你翻译成A国语言,讲给对方听,这个场景大伙应该不生疏,这就是解释型语言的运行过程;
https://i-blog.csdnimg.cn/blog_migrate/b90904b55aa0be55756a744bbc90b14f.png
形象化解释型语言整个过程
https://i-blog.csdnimg.cn/blog_migrate/05c0d0b918d78be2d8f034a1c130d828.png
解释型语言的编译执行过程
而假如你会A国的语言,可以直接表达出你的想法,这个就是编译型语言的运作过程:
https://i-blog.csdnimg.cn/blog_migrate/17d2d7f84aa1077ac94eedeb462a38b6.png
形象化编译型语言
https://i-blog.csdnimg.cn/blog_migrate/e67921dc7998fc341014350248a0d08a.png
编译型语言编译执行过程
很显着,编译型语言的运行效率要远远高于解释型语言,而我们常说的JVM(Java虚拟机)就是翻译官的经典代表,它的一部分职责就是做这个翻译的工作,固然它还有其他工作。而解释型语言的代表就是耳熟能详的C/C++、Rust,以及IOS应用的开辟语言,Object-C、Swift等。所以现在应该能明白,为啥苹果就是流畅,安卓不管怎么优化都会卡,这是其中一个重要的原因。
在《编译原理》这门课程中,Java作为解释型语言的一个代表,它是不能脱离JVM而单独运行,但是厥后Java为了提高运行效率,陆续推出了JIT技术、AOT等技术,以此来提高Java的运行效率,这也是很多人认为它是编译型语言的原因。
https://i-blog.csdnimg.cn/blog_migrate/10d0e5faa6d5ebccbae44eb9dba39f22.png
形象化JIT和AOT技术
JIT技术:类似于你说的一些高频词语,翻译官经常翻译跋文住了,背面再有相同大概相似的词语句的时候,不需要再经过翻译,可以脱口而出,提高效率。
AOT技术:类似于一些开场固定话术,常用话术,你在见对方前,先背诵下来,直接说出来,比如“你好”,“很高兴见到你”等词语,可以肯定水平上减少翻译官的翻译时间。
可以看到,JIT和AOT技术的引入,确实提高了整体的执行效率,但是,但是,你会一些A国语言,和你完全会这门语言还是有天差地别的区别的!
PS:增补几点
1)JVM的功能很强大,并不但有上面说的那么一点功能,具体不赘述了,轻易跑题
2)Java代码自己也不能被JVM所识别,要先编译成字节码,然后才能被JVM识别,然后再由JVM翻译成机器码才能被执行
3)JVM因为功能很强大,所以很斲丧资源,谷歌在安卓5.0的时候彻底启用了新的虚拟机,所以从安卓5.0开始,整个安卓的流畅性比4.4以前提高了很多
2.ts的性能能比肩Java?
通过开源鸿蒙的主页,可以或许看到,TypeScript代码量非常薄,重要的体系代码都在C/C++,Rust这些编译语言为主。
https://i-blog.csdnimg.cn/blog_migrate/fab3ae9e93e3a70a35fa8bd302f09fd0.png
开源鸿蒙的语言占比
ts的性能在正常环境下,是比不过Java的,这是不争的究竟!
不过,不过大家应该听过两个编译器:方舟编译器和毕昇编译器。
方舟编译器:这个大伙应该不生疏,在官网上有先容,我这里不赘述了。
https://i-blog.csdnimg.cn/blog_migrate/fedfdb4c5868c10d577488fe84096b65.png它按照官方说法,它的作用就是通过AOT技术把部分ets编译成机器可以直接识别的代码,另外一部分不能被编译成机器能识别的,就编译成方舟字节码,通过方舟运行时来执行,由于经过了各种优化,执行效率非常的高,开源鸿蒙里也有对它的详细先容,链接如下:
方舟运行时子体系先容
毕昇编译器:这是一个高性能深度优化的C/C++编译器,可以各种提高C/C++的执行效率!
https://i-blog.csdnimg.cn/blog_migrate/657f5396d25569a6ed7c946d74de35cd.png
在华为还在使用安卓体系的时候,通过方舟编译器优化过的同一应用,启动速度和使用的流畅度,都会得到肯定的提升,这个网上有很多测试视频,感爱好的朋友可以去搜搜。
https://i-blog.csdnimg.cn/blog_migrate/aa55ad3c0a23d9563a3c5b44f5556154.png
根据上面的资料和总结,整体的体系运行应该是上图所示,首先ets代码量并不多,后端逻辑重要用C/C++去写的,C++这块经过毕昇编译后,效率得到了很大的提升,而ets的执行部分,也是经过了各种优化,效率得到了提升,所以整体的执行效率并不低。
3.纯血鸿蒙体系,内部还有“翻译官”吗?
正如2所说的,方舟编译器不能完全的翻译ets,一些不能翻译的代码,还是会通过“翻译官”翻译给机器,所以还是有的,只是它很轻量级,不像JVM那么重,对性能的影响非常小。
总结:
ets的性能在正常环境下是无法比得过Java的执行效率,而在方舟编译器和毕昇编译器的特殊优化下,可以取得更高地执行效率;之所以选择ts作为开辟语言,因为每一个体系都需要配套的生态软件才能长久,而Java需要拖一个JVM,会低沉运行效率,而C++门槛比较高,所以选择了有肯定开辟者基数,没有版权标题,且还能通过编译器提高运行效率的语言,所以华为选择了TypeScript。
所有的技术,即使吹的再多,最终都是要回归到用户体验上来的,假如明年的鸿蒙Next版本不能给人丝滑流畅的感觉,那终归还是让人扫兴的,盼望鸿蒙Next明年可以绽放光彩!
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]