【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 检索所有的引用对象 , 检查哪些对象需要被回收 ;


目录
打赏
0
0
0
0
39
分享
相关文章
快速定位并优化CPU 与 JVM 内存性能瓶颈
本文介绍了 Java 应用常见的 CPU & JVM 内存热点原因及优化思路。
729 166
Java虚拟机(JVM)的垃圾回收机制深度解析####
本文深入探讨了Java虚拟机(JVM)的垃圾回收机制,旨在揭示其背后的工作原理与优化策略。我们将从垃圾回收的基本概念入手,逐步剖析标记-清除、复制算法、标记-整理等主流垃圾回收算法的原理与实现细节。通过对比不同算法的优缺点及适用场景,为开发者提供优化Java应用性能与内存管理的实践指南。 ####
|
4月前
|
Java虚拟机(JVM)垃圾回收机制深度剖析与优化策略####
本文作为一篇技术性文章,深入探讨了Java虚拟机(JVM)中垃圾回收的工作原理,详细分析了标记-清除、复制算法、标记-压缩及分代收集等主流垃圾回收算法的特点和适用场景。通过实际案例,展示了不同GC(Garbage Collector)算法在应用中的表现差异,并针对大型应用提出了一系列优化策略,包括选择合适的GC算法、调整堆内存大小、并行与并发GC调优等,旨在帮助开发者更好地理解和优化Java应用的性能。 ####
108 0
如何快速定位并优化CPU 与 JVM 内存性能瓶颈?
如何快速定位并优化CPU 与 JVM 内存性能瓶颈?
2025年阿里云服务器配置选择全攻略:CPU、内存、带宽与系统盘详解
在2025年,阿里云服务器以高性能、灵活扩展和稳定服务助力数字化转型,提供轻量应用服务器、通用型g8i实例等多样化配置,满足个人博客至企业级业务需求。针对不同场景(如计算密集型、内存密集型),推荐相应实例类型与带宽规划,强调成本优化策略,包括包年包月节省成本、ESSD云盘选择及地域部署建议。文中还提及安全设置、监控备份的重要性,并指出未来可关注第九代实例g9i支持的新技术。整体而言,阿里云致力于帮助用户实现性能与成本的最优平衡。 以上简介共计238个字符。
别让你的CPU打盹儿:Apache Doris并行执行原理大揭秘!
别让你的CPU打盹儿:Apache Doris并行执行原理大揭秘!
217 1
别让你的CPU打盹儿:Apache Doris并行执行原理大揭秘!
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
404 7
深入探索Java虚拟机(JVM)的内存管理机制
本文旨在为读者提供对Java虚拟机(JVM)内存管理机制的深入理解。通过详细解析JVM的内存结构、垃圾回收算法以及性能优化策略,本文不仅揭示了Java程序高效运行背后的原理,还为开发者提供了优化应用程序性能的实用技巧。不同于常规摘要仅概述文章大意,本文摘要将简要介绍JVM内存管理的关键点,为读者提供一个清晰的学习路线图。
网站应用项目如何选择阿里云服务器实例规格+内存+CPU+带宽+操作系统等配置
对于使用阿里云服务器的搭建网站的用户来说,面对众多可选的实例规格和配置选项,我们应该如何做出最佳选择,以最大化业务效益并控制成本,成为大家比较关注的问题,如果实例、内存、CPU、带宽等配置选择不合适,可能会影响到自己业务在云服务器上的计算性能及后期运营状况,本文将详细解析企业在搭建网站应用项目时选购阿里云服务器应考虑的一些因素,以供参考。
Java虚拟机(JVM)垃圾回收机制深度解析与优化策略####
本文旨在深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法及参数调优方法。通过剖析垃圾回收的生命周期、内存区域划分以及GC日志分析,为开发者提供一套实用的JVM垃圾回收优化指南,助力提升Java应用的性能与稳定性。 ####

热门文章

最新文章