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


目录
相关文章
|
19天前
|
弹性计算 Kubernetes Perl
k8s 设置pod 的cpu 和内存
在 Kubernetes (k8s) 中,设置 Pod 的 CPU 和内存资源限制和请求是非常重要的,因为这有助于确保集群资源的合理分配和有效利用。你可以通过定义 Pod 的 `resources` 字段来设置这些限制。 以下是一个示例 YAML 文件,展示了如何为一个 Pod 设置 CPU 和内存资源请求(requests)和限制(limits): ```yaml apiVersion: v1 kind: Pod metadata: name: example-pod spec: containers: - name: example-container image:
112 1
|
28天前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
239 2
|
2月前
|
存储 算法 Java
Java虚拟机(JVM)的内存管理与性能优化
本文深入探讨了Java虚拟机(JVM)的内存管理机制,包括堆、栈、方法区等关键区域的功能与作用。通过分析垃圾回收算法和调优策略,旨在帮助开发者理解如何有效提升Java应用的性能。文章采用通俗易懂的语言,结合具体实例,使读者能够轻松掌握复杂的内存管理概念,并应用于实际开发中。
|
3月前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
160 5
|
2月前
|
运维 JavaScript Linux
容器内的Nodejs应用如何获取宿主机的基础信息-系统、内存、cpu、启动时间,以及一个df -h的坑
本文介绍了如何在Docker容器内的Node.js应用中获取宿主机的基础信息,包括系统信息、内存使用情况、磁盘空间和启动时间等。核心思路是将宿主机的根目录挂载到容器,但需注意权限和安全问题。文章还提到了使用`df -P`替代`df -h`以获得一致性输出,避免解析错误。
|
3月前
|
存储 算法 Java
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
本文介绍了 JVM 的内存区域划分、类加载过程及垃圾回收机制。内存区域包括程序计数器、堆、栈和元数据区,每个区域存储不同类型的数据。类加载过程涉及加载、验证、准备、解析和初始化五个步骤。垃圾回收机制主要在堆内存进行,通过可达性分析识别垃圾对象,并采用标记-清除、复制和标记-整理等算法进行回收。此外,还介绍了 CMS 和 G1 等垃圾回收器的特点。
117 0
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
|
2月前
|
C# 开发工具 Windows
C# 获取Windows系统信息以及CPU、内存和磁盘使用情况
C# 获取Windows系统信息以及CPU、内存和磁盘使用情况
47 0
|
3月前
|
Prometheus Kubernetes 监控
使用kubectl快速查看各个节点的CPU和内存占用量
在Kubernetes集群中,安装metrics-server,并使用kubectl快速查看集群中各个节点的资源使用情况。
172 0
|
3月前
使用qemu来dump虚拟机的内存,然后用crash来分析
使用qemu来dump虚拟机的内存,然后用crash来分析
|
5月前
|
算法 Java 开发者
Java面试题:Java内存探秘与多线程并发实战,Java内存模型及分区:理解Java堆、栈、方法区等内存区域的作用,垃圾收集机制:掌握常见的垃圾收集算法及其优缺点
Java面试题:Java内存探秘与多线程并发实战,Java内存模型及分区:理解Java堆、栈、方法区等内存区域的作用,垃圾收集机制:掌握常见的垃圾收集算法及其优缺点
39 0