Dalvik与JVM的区别

来源:互联网 发布:天健医疗软件 编辑:程序博客网 时间:2024/06/14 02:45

今天面试被问到这个,没答上来很尴尬。。之前一直在针对android事件分发,View绘制,消息机制与图片缓存和Java基础知识,从面试中找到自己的不足。

  1. Dalvik支持的格式
    它支持已转换为.dex(Dalvik Executable)格式的Java程序的运行,.dex是专门为Dalvik设计的一种压缩格式,适合内存和处理器速度有限的系统。(dx是一套工具,可以将Java .class转换为.dex格式。一个dex文档通常会有多个.class。由于dex有时必须进行最佳化,会使档案大小增加1-4倍,以ODEX结尾)
  2. Dalvik与JVM的最大差别
    Dalvik 基于寄存器,而 JVM 基于。基于寄存器的虚拟机对于更大的程序来说,在它们编译的时候,花费的时间更短。 JVM字节码中,局部变量会被放入局部变量表中,继而被压入堆栈供操作码进行运算,当然JVM也可以只使用堆栈而不显式地将局部变量存入变量表中。Dalvik字节码中,局部变量会被赋给65536个可用的寄存器中的任何一个,Dalvik指令直接操作这些寄存器,而不是访问堆栈中的元素。
  3. Dalvik与Java字节码的区别
    VM字节码由.class文件组成,每个文件一个class。JVM在运行的时候为每一个类装载字节码。相反的,Dalvik程序只包含一个.dex文件,这个文件包含了程序中所有的类。Java编译器创建了JVM字节码之后,Dalvik的dx编译器删除.class文件,重新把它们编译成Dalvik字节码,然后把它们写进一个.dex文件中。这个过程包括翻译、重构、解释程序的基本元素(常量池、类定义、数据段)。常量池描述了所有的常量,包括引用、方法名、数值常量等。类定义包括了访问标志、类名等基本信息。数据段中包含各种被VM执行的函数代码以及类和函数的相关信息(例如DVM所需要的寄存器数量、局部变量表、操作数堆栈大小),还有实例变量。

  4. Dalvik 和 Java SDK的SDK不同

  5. Dalvik 和 Java 运行环境的区别
    Dalvik 经过优化,允许在有限的内存中同时运行多个虚拟机的实例,并且每一个Dalvik 应用作为一个独立的Linux 进程执行。独立的进程可以防止在虚拟机崩溃的时候所有程序都被关闭。
    Dalvik虚拟机在android2.2之后使用JIT (Just-In-Time)技术,与传统JVM的JIT并不完全相同, 

    Dalvik虚拟机有自己的 bytecode,并非使用 Java bytecode。

  6. 有一个特殊的虚拟机进程Zygote,他是虚拟机实例的孵化器。它在系统启动的时候就会产生,它会完成虚拟机的初始化、库的加载、预制类库和初始化的操作。如果系统需要一个新的虚拟机实例,它会迅速复制自身,以最快的速度提供给系统。对于一些只读的系统库,所有虚拟机实例都和Zygote共享一块内存区域。
0 0
原创粉丝点击