首页> 中文学位 >Java虚拟机内存管理及其实时性的研究
【6h】

Java虚拟机内存管理及其实时性的研究

代理获取

目录

文摘

英文文摘

声明

第一章 绪论

1.1 研究背景、目的及意义

1.2 研究现状

1.3 本文研究的内容

第二章 实时系统与实时Java

2.1 实时系统

2.1.1 实时系统的概念

2.1.2 实时系统的特性

2.1.3 硬实时与软实时

2.2 实时Java

2.2.1 Java与实时Java

2.2.2 实时Java规范

第三章 实时Java虚拟机及其内存管理

3.1 实时Java虚拟机与嵌入式实时系统

3.2 普通Java虚拟机的内存管理

3.2.1 方法区

3.2.2 Java堆

3.2.3 Java 栈

3.2.1 寄存器

3.2.1 本地方法栈

3.3 实时Java虚拟机的内存管理

3.3.1 内存区域的管理

3.3.2 垃圾收集

3.3.3 内存分配时间

3.3.4 对象引用规则

第四章 实时内存管理机制的设计

4.1 内存区域模型

4.2 线程的改进

4.2.1 实时线程模拟

4.2.2 Scope Stack的实现

4.3 内存区域的分配与回收

4.3.1 内存区域的分配

4.3.2 内存区域的回收

4.3.3 一个示例

4.3.4 内存分配时间

4.4 内存引用检查

4.5 垃圾收集器的改进

4.5.1 传统的拷贝垃圾收集器的实现

4.5.2 对垃圾收集器的改进

第五章 实验结果与分析

5.1 实现方法

5.2 实验结果与分析

5.2.1 固定分配内存实验

5.2.2 递增分配内存实验

5.2.3 总结

第六章 总结与展望

致 谢

参考文献

附录:作者在攻读硕士学位期间发表的论文

展开▼

摘要

Java语言的面向对象,平台无关,安全,开发效率高等特点,使其在许多领域中得到了越来越广泛的应用。但是由于Java程序由于自身的局限性,使其无法应用于实时领域。由于垃圾收集器运行时将中断Java程序的运行,其运行时刻和垃圾搜集时间具有不确定性。在应用程序高频率分配和释放内存时,垃圾收集要占用的时间可能比程序自身运行的时间还要多。这些都使得Java程序无法满足在实时领域应用的要求。
   Java实时规范(RTSJ)的内存管理机制既保证了Java本身的内存安全的优势,同时又保证了在实时系统中对内存操作的的可预测性。不产生垃圾的代码不会导致请求式的垃圾收集;不引用堆中对象的代码可以抢占垃圾收集器的线程。为了能够保留垃圾收集的好处又能避免垃圾收集器对实时特性的影响,基于以上两个事实RTSJ扩展了Java内存管理机制,在传统的堆内存的基础上,又提出了内存区域(Memory Area)的概念。在新增加的这几个内存区域中分配对象不会导致垃圾收集器的执行,不会使系统受到其不可预测性的影响。
   本文根据RTSJ的要求,介绍了RTSJ内存管理机制实现的各个基本要点,包括使用Display树的内存引用检查,LTMemory和VTMemory的分配机制,ScopeStack的维护等。文章通过研究一个可运行在多种操作系统并兼容多种硬件平台的开源的Java虚拟机SableVM的基础上,结合国内外最新的理论,提出了一个对其实时性进行改进的方案,并对其进行实验。该方案有别于国内外现有的实时Java虚拟机的实现,在内存管理方面即符合RTSJ的要求,同时又保证了Java程序可移植性的要求。

著录项

相似文献

  • 中文文献
  • 外文文献
  • 专利
代理获取

客服邮箱:kefu@zhangqiaokeyan.com

京公网安备:11010802029741号 ICP备案号:京ICP备15016152号-6 六维联合信息科技 (北京) 有限公司©版权所有
  • 客服微信

  • 服务号