`
风残月
  • 浏览: 1767 次
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

java数据存储的六种形态

    博客分类:
  • java
阅读更多
(1) 寄存器。这是最快的保存区域,因为它位于和其他所有保存方式不同的地方:处理器内部。然而,寄存
器的数量十分有限,所以寄存器是根据需要由编译器分配。我们对此没有直接的控制权,也不可能在自己的
程序里找到寄存器存在的任何踪迹。
(2) 堆栈。驻留于常规RAM(随机访问存储器)区域,但可通过它的“堆栈指针”获得处理的直接支持。堆
栈指针若向下移,会创建新的内存;若向上移,则会释放那些内存。这是一种特别快、特别有效的数据保存
方式,仅次于寄存器。创建程序时,Java 编译器必须准确地知道堆栈内保存的所有数据的“长度”以及“存
在时间”。这是由于它必须生成相应的代码,以便向上和向下移动指针。这一限制无疑影响了程序的灵活
性,所以尽管有些Java 数据要保存在堆栈里——特别是对象句柄,但Java 对象并不放到其中。
47
(3) 堆。一种常规用途的内存池(也在RAM 区域),其中保存了Java 对象。和堆栈不同,“内存堆”或
“堆”(Heap)最吸引人的地方在于编译器不必知道要从堆里分配多少存储空间,也不必知道存储的数据要
在堆里停留多长的时间。因此,用堆保存数据时会得到更大的灵活性。要求创建一个对象时,只需用new 命
令编制相关的代码即可。执行这些代码时,会在堆里自动进行数据的保存。当然,为达到这种灵活性,必然
会付出一定的代价:在堆里分配存储空间时会花掉更长的时间!
(4) 静态存储。这儿的“静态”(Static)是指“位于固定位置”(尽管也在RAM 里)。程序运行期间,静
态存储的数据将随时等候调用。可用static 关键字指出一个对象的特定元素是静态的。但Java 对象本身永
远都不会置入静态存储空间。
(5) 常数存储。常数值通常直接置于程序代码内部。这样做是安全的,因为它们永远都不会改变。有的常数
需要严格地保护,所以可考虑将它们置入只读存储器(ROM)。
(6) 非RAM 存储。若数据完全独立于一个程序之外,则程序不运行时仍可存在,并在程序的控制范围之外。
其中两个最主要的例子便是“流式对象”和“固定对象”。对于流式对象,对象会变成字节流,通常会发给
另一台机器。而对于固定对象,对象保存在磁盘中。即使程序中止运行,它们仍可保持自己的状态不变。对
于这些类型的数据存储,一个特别有用的技巧就是它们能存在于其他媒体中。一旦需要,甚至能将它们恢复
成普通的、基于RAM 的对象。Java 1.1 提供了对Lightweight persistence 的支持。未来的版本甚至可能提
供更完整的方案。
本文出自 “vanchao博客” 博客,请务必保留此出处http://sxchao.blog.51cto.com/907640/874145
分享到:
评论

相关推荐

    java数据结构面试题

    ### Java数据结构面试题知识点详解 #### 一、栈与队列的特点 - **栈**:栈是一种特殊的线性表,只允许在一端(称为栈顶)进行插入和删除操作,具有“后进先出”(Last In First Out, LIFO)的特性。常见的存储结构有...

    java中读取shp文件数据存入数据库

    shp文件:地理信息系统,也被称作GIS,它主要的扩展类型是SHAPEFILE (.SHP),一个包含了矢量地理空间数据的流行文件格式,描述了几何形态,点,线和多边形,每一个都有他们各自的属性。 shape文件由ESRI开发,一个...

    数据结构(java版)习题解答

    ### 数据结构(Java版)习题解答概览 #### 第0章 Java程序设计基础 **实验0.1:哥德巴赫猜想** - **题目**:实现哥德巴赫猜想,即任何大于2的偶数都可以表示为两个质数之和。 - **解答**:通过编写一个函数来检测...

    2022年java数据结构面试题.doc

    这些知识点是Java数据结构面试中常见的主题,理解和掌握它们对于准备面试至关重要。在实际面试中,可能会被要求设计算法、分析时间复杂度和空间复杂度,或者解决实际问题,例如使用特定数据结构来优化程序性能。因此...

    java数据结构面试题.pdf

    数据结构是计算机科学的基础,它...这些知识点是Java数据结构面试中常见的问题,涵盖栈、队列、链表、树和二叉树、算法分析等核心概念。理解并能熟练运用这些概念,对于解决实际编程问题和在面试中脱颖而出至关重要。

    java数据结构 树与二叉树

    Java中的数据结构——树与二叉树是编程中不可或缺的一部分,它们在算法设计、数据存储和问题解决中扮演着重要角色。本节将详细介绍树和二叉树的概念、性质以及在Java中的实现。 首先,树是一种非线性的数据结构,由...

    Java数据结构题.docx

    ### Java数据结构题知识点解析 #### 一、栈和队列的特点 - **共同特点**:栈和队列都是线性的数据结构,它们都只允许在端点处进行插入和删除操作。具体来说: - **栈**:遵循后进先出(LIFO, Last In First Out)的...

    Java数据结构之树与二叉树.pptx

    Java中的数据结构是编程中非常基础且重要的概念,特别是树和二叉树,它们在算法设计、数据存储和处理中有着广泛的应用。本文件主要介绍了树和二叉树的定义、性质以及它们在Java中的实现。 首先,树是一种非线性的...

    Java的笔记,记录Java的基础知识

    1. 变量与数据类型:Java有八种基本数据类型,包括整型(byte, short, int, long)、浮点型(float, double)、字符型(char)和布尔型(boolean)。变量是用来存储数据的容器,声明时需指定数据类型。 2. 控制结构...

    Java 入门word笔记

    1. XML简介:XML(Extensible Markup Language)是一种可扩展标记语言,用于存储和传输结构化数据。 2. DOM解析:DOM(Document Object Model)将XML文档解析为树形结构,可以遍历节点进行读写操作。Java提供了...

    数据结构面试题 java面试题

    本题集主要涵盖了数据结构中的栈、队列、链表、树、二叉树以及算法的相关知识,这些都是Java面试中常见的问题。 栈和队列是两种基本的线性数据结构。栈遵循“后进先出”(LIFO)原则,即最后进入的元素最先离开。...

    Java复习题.pdf

    本文将对Java基础知识点进行总结,涵盖Java的历史、版本、 JVM、JDK、JRE、Java开发环境、Java程序的生命周期、Java程序的形态、Java变量、Java数据类型、Java运算符、Java控制结构、Java函数、Java数组、Java对象、...

    Javatree java树结构

    Java树结构是计算机科学中的一种数据结构,它模拟了自然界中的树形态,通过节点和边来组织数据。在Java编程中,树结构被广泛应用于数据的组织和操作,如文件系统、编译器语法分析、搜索算法等。下面将详细阐述Java树...

Global site tag (gtag.js) - Google Analytics