download:Vue3+Nuxt3打造SSR网站利用,0到1实现服务端渲染无密
基础知识
本章不会介绍java语言自身,置信大家对此已有足够相熟。绝对的,会从工程利用角度,解说几个有意思的技术点。
1.1 由源码到apk
源代码是如何经验多重解决,最终出现在apk中,理解这个过程,有助于咱们认清java代码腐化的一些起因。从apk构建视角来看,java(kotlin)
代码残缺处理过程如下:
上述流程中,无论是java还是kotlin代码,都会首先编译为jvm字节码。这里须要留神,app/子工程中的local jar、flat aar
,以及通过内部依赖形式引入的jar、aar,都是间接蕴含编译好的jvm字节码,这会带来如下优劣势:
- 【劣势】无需再进行由源码到字节码的编译,在代码完全相同状况下,工程的模块化(jar/aar)水平越高,越可能缩短整体apk构建耗时;
- 【劣势】提前编译好的jvm字节码,不会再进行源码编译期各项查看,容易呈现代码间援用关系不匹配状况,具体后文「不兼容援用」局部会详述。
- 此外,对于jvm和Dalvik字节码,一个最外围的区别是:前者的指令,基于栈,后者基于寄存器。基于寄存器的劣势,次要是运行时指令执行性能的晋升。此外,jvm字节码,每个类位于独立.class文件,而dalvik字节码,所有类均位于同一(几)个dex文件,可能更好的复用代码数据,因而存储占用更低。
1.2 应用java8
java8是一个比拟有代表性的java语言版本,在Android中应用java8,这个话题自身会比较复杂。首先,从java8新内容来看,次要分为新语言个性和新API;其次,从编码到运行的整个链路来看,波及编译工具链、设施预装jdk、设施vm(Dalvik/Art
)三个局部的反对;此外,Android自身应用的jdk并不是规范的oracle jdk或openjdk,而是进行了一些定制后的子集。
java8新语言特性,有一些波及到新的jvm指令集,这些须要运行时vm可能反对。否则,就须要在编译工具链中,可能应用兼容的指令集来替换这些新指令集的性能,这个过程就是大家相熟的“脱糖”,AndroidGradlePlugin3.0及以上版本,曾经对此实现了较好的反对。因为Android零碎中Art虚拟机,直到8.0版本,才齐全实现对java8新指令集的反对,因而当apk构建的minSdkVersion
设置为26(8.0)以下时,会触发脱糖解决