【Java 虚拟机原理】Dalvik 虚拟机 ( 简介 | CPU 指令集 | Dalvik 虚拟机内存 )

简介: 【Java 虚拟机原理】Dalvik 虚拟机 ( 简介 | CPU 指令集 | Dalvik 虚拟机内存 )

文章目录

一、Dalvik 虚拟机简介

二、CPU 指令集

三、Dalvik 虚拟机内存





一、Dalvik 虚拟机简介


Android 5.0 5.05.0 之前使用的是 Dalvik 虚拟机 , 5.0 5.05.0 之后使用的是 ART 虚拟机 ;


Dalvik 虚拟机 也是 Java 虚拟机的一种 , 但是其没有获得 Sun 的测试审核 , 经过 Sun 公司测试 , 审核 , 授权后 , 虚拟机才能叫做 Java 虚拟机 , 只是名字上有区别 , 但是其还是符合 JVM 规范的 ;


同理 , 手机厂商必须经过 Google 测试审核之后 , 才能叫 Android 手机 ;



Dalvik 虚拟机 的 内存结构 , 与 JVM 有一定的区别 ;


JVM 主要在 PC 端使用 , 运行在 x86 架构 CPU 上 ;

DVM 主要是在手机端使用 , 运行在 arm 架构 CPU 上 , DVM 的内存优化比较高 ;





二、CPU 指令集


不同架构上的 Java 虚拟机 实现也是不同的 ;


CPU 架构参考 【C 语言】CPU 架构 ( CPU 指令集类型 | CPU 指令类型 | CPU 架构 )


RISC : Reduced Instruction Set Computers , 精简指令集 , 手机使用的 ARM 芯片 ( 高通 ) 就是精简指令集 , Android 是基于 ARM 架构的操作系统 ;


CISC : Complex Instruction Set Computers , 复杂指令集 , PC 机的 x86 架构 CPU ( Intel , AMD ) 就是复杂指令集 ; Linux , Windows 是基于 x86 架构的操作系统 ;



复杂指令集示例 : 复杂指令集中 , 所有的动作都是定义好的 ,


以做菜为例 : 洗菜 , 切菜 , 炒菜 , 放调料 , 装盘 ; 将所有步骤定义好 ; 只要 5 55 个指令 , 就可以完成 ;

运行速度高 , 效率高 , 功耗低 ;

精简指令集示例 : 精简指令集中 , 只有最基础的指令 , 复杂指令需要自己合成 ;


以做菜为例 : 洗菜 ( 放水 , 放菜 , 搅拌 , 沥干 ) , 切菜 ( 准备案板 , 准备菜刀 , 切片 ) , 炒菜 ( 起锅 , 烧油 ) , 放调料 ( 放花生油 , 放酱油 , 放盐 ) , 装盘 ( 准备盘子 , 从锅里倒在盘子中 ) ; 需要 14 1414 个指令 , 才能完成 ;

需要为每个步骤输入指令 , 速度慢 , 效率低 , 功耗高 ;


CPU 位数 : 64 / 32 64 / 3264/32 位 , 表示单次读取指令的吞吐量 , 64 6464 位表示一次可以读取 64 6464 位 ( 8 88 Byte ) 的指令 ;






三、Dalvik 虚拟机内存


DVM 堆分为 2 22 部分 , Active Heap 和 Zygote Heap ;


Android 系统刚启动的时候 , 没有启动应用 , 只有 Zygote 进程 , 所有的应用都是 Zygote 进程 fork() 启动的 ;


Zygote Heap 就是 Zygote 进程的堆 ;


当有第一个 Android 应用进程启动后 , 就会出现 Active Heap 堆 ;


image.png



DVM 内存划分 :


Zygote Heap 堆内存中 , 有一部分区域的内存是只读的 , 如系统相关的库 , 共享库 , 预置库 , 这些内存数据所有应用公用 ;


每个应用都会在 Active Heap 堆中分配一块内存 ;



DVM 借助一些 辅助数据结构 管理堆内存 ;


Card Table : 记录对象的引用情况 , 辅助 CMS 并行垃圾回收器使用 ;

Live Heap Bitmap : 记录上一次 GC 后存活的对象 ;

Mark Heap Bitmap : 记录当前存活的对象 ;

上一次存活 , 本次没有存活的对象 , 是本次需要被回收的对象 ; 这些对象由 Mark Stack 找出 ;


Mark Stack 检索所有的引用对象 , 检查哪些对象需要被回收 ;


目录
相关文章
|
8月前
|
人工智能 安全 Java
Go与Java泛型原理简介
本文介绍了Go与Java泛型的实现原理。Go通过单态化为不同类型生成函数副本,提升运行效率;而Java则采用类型擦除,将泛型转为Object类型处理,保持兼容性但牺牲部分类型安全。两种机制各有优劣,适用于不同场景。
359 24
|
存储 缓存 算法
JVM简介—1.Java内存区域
本文详细介绍了Java虚拟机运行时数据区的各个方面,包括其定义、类型(如程序计数器、Java虚拟机栈、本地方法栈、Java堆、方法区和直接内存)及其作用。文中还探讨了各版本内存区域的变化、直接内存的使用、从线程角度分析Java内存区域、堆与栈的区别、对象创建步骤、对象内存布局及访问定位,并通过实例说明了常见内存溢出问题的原因和表现形式。这些内容帮助开发者深入理解Java内存管理机制,优化应用程序性能并解决潜在的内存问题。
648 29
JVM简介—1.Java内存区域
|
8月前
|
人工智能 Java
java中static关键字简介
`static`关键字用于修饰类的成员变量和方法,使其属于类而非对象。静态成员可通过类名直接访问,无需实例化对象。静态方法只能访问静态成员,不能直接访问非静态成员或使用`this`关键字。此外,静态代码块在类首次加载时执行且仅执行一次,适用于初始化操作。
226 0
|
9月前
|
存储 缓存 程序员
软考软件评测师——计算机组成与体系结构(CPU指令系统)
本内容详细解析了计算机中央处理器(CPU)的核心架构及其关键组件的工作原理。首先介绍了CPU的四大核心模块:运算单元、控制单元、寄存器阵列和内部总线,并阐述其在数据处理中的核心职责。接着深入探讨了算术逻辑部件(ALU)的功能与专用寄存器的作用,以及通用寄存器对性能提升的意义。随后分析了控制单元的指令处理流程及特殊寄存器的功能。此外,还解析了寄存器系统的分类与设计特点,并对比了不同内存访问模式的特点与应用场景。最后,通过历年真题巩固相关知识点,帮助理解CPU各组件的协同工作及优化策略。
|
缓存 监控 算法
JVM简介—2.垃圾回收器和内存分配策略
本文介绍了Java垃圾回收机制的多个方面,包括垃圾回收概述、对象存活判断、引用类型介绍、垃圾收集算法、垃圾收集器设计、具体垃圾回收器详情、Stop The World现象、内存分配与回收策略、新生代配置演示、内存泄漏和溢出问题以及JDK提供的相关工具。
JVM简介—2.垃圾回收器和内存分配策略
|
存储 Java 编译器
JVM简介—3.JVM的执行子系统
本文详细介绍了Java类的加载、执行及其相关机制,涵盖Class文件结构、字节码指令、类加载器、双亲委派模型、栈桢和方法调用等内容。
JVM简介—3.JVM的执行子系统
|
监控 测试技术 数据库
详解Hyper-V虚拟机CPU分配方法
在Hyper-V环境中,合理分配虚拟机的CPU资源至关重要。vCPU是物理CPU的虚拟化表示,管理员可通过指定处理器数量、核心数、设置兼容性和亲和性、启用动态分配等方法优化性能。使用性能监视工具监控并调整CPU资源,避免过度分配,确保虚拟机稳定运行。定期评估和优化资源分配策略,以适应业务变化,保持最佳性能。
|
Java Linux API
课时3:Java简介(Java主要特点)
本文介绍了Java的主要特点及其运行机制。Java结合了编译型和解释型语言的优点,通过Java虚拟机(JVM)实现跨平台移植,简化了不同操作系统间的开发流程。Java的特点包括可移植性、简单易用、支持多线程编程、自动垃圾收集和面向对象编程。随着硬件技术的发展,Java的性能问题已大大改善,成为行业标准之一,广泛应用于各种商用平台开发。
349 1
|
存储 监控 算法
深入探索Java虚拟机(JVM)的内存管理机制
本文旨在为读者提供对Java虚拟机(JVM)内存管理机制的深入理解。通过详细解析JVM的内存结构、垃圾回收算法以及性能优化策略,本文不仅揭示了Java程序高效运行背后的原理,还为开发者提供了优化应用程序性能的实用技巧。不同于常规摘要仅概述文章大意,本文摘要将简要介绍JVM内存管理的关键点,为读者提供一个清晰的学习路线图。
|
存储 JavaScript Java
Java 中的 String Pool 简介
本文介绍了 Java 中 String 对象及其存储机制 String Pool 的基本概念,包括字符串引用、构造方法中的内存分配、字符串文字与对象的区别、手工引用、垃圾清理、性能优化,以及 Java 9 中的压缩字符串特性。文章详细解析了 String 对象的初始化、内存使用及优化方法,帮助开发者更好地理解和使用 Java 中的字符串。
229 2
Java 中的 String Pool 简介