Day1-1.Where Storage lives

来源:互联网 发布:大数据在教育行业应用 编辑:程序博客网 时间:2024/06/05 04:14

当程序运行时,对象是怎么进行放置安排的?内存是怎样分配的?

五个不同的存储数据的地方:
1.寄存器。Registers
最快的存储区,因为它位于处理器内部。但是寄存器的数量有限,所以要按需求进行分配。
程序员不能直接控制,也无法在程序中感受到寄存器存在的迹象。
(另一方面,C和C++允许向编译器建议寄存器的分配方式)
2.堆栈。 The stack
位于通用RAM(随机访问存储器)中,但通过堆栈指针可以从处理器那里获得直接支持。
堆栈指针若向下移动,则分配新的内存;若向上移动,则释放那些内存。
这是一种快速有效的分配存储方法,仅次于寄存器。
创建程序时,Java系统必须知道存储在堆栈内所有项的确切生命周期,以便上下移动堆栈指针。
这一约束限制了程序的灵活性,所以虽然某些Java数据存储于堆栈中--特别是对象引用,但是Java对象并不存储于其中。
3.堆 the heap
一种通用的内存池(也位于RAM区),用于存放所有的Java对象。
堆不同于堆栈的好处是:编译器不需要知道存储的数据在堆里存活多长时间。
因此,在堆里分配存储有很大的灵活性。
当需要一个对象时,只需用new写一行简单的代码,当执行这行代码时,会自动在堆里进行存储分配。
当然,为这种灵活性必须要付出相应的代价:用堆进行存储分配和清理可能比用堆栈进行存储分配分配需要更多的时间。
4.常量存储。
常量值通常直接存放在程序代码内部,这样做事安全的,因为它们不会被改变。
有时,在嵌入式系统中,常量本身会和其他部分隔离开,所以这种情况下,可以选择将其存放在ROM(只读存储器)中。
(这种存储区的一个例子时字符串池。所有字面常量字符串和具有字符串值得常量表达式都自动是内存限定的,
并且会至于特殊的静态存储区中)
5.非RAM存储。
如果数据完全存活于程序之外,那么它可以不受程序的任何控制,在程序没有运行时也可以存在。
其中两个基本的例子是流对象(streamed objects)和持久化对象(persistent objects)。
在流对象中,对象转化成字节流,通常被发送给另一台机器。
在“持久化对象”中,对象被存放于磁盘上,因此即使程序终止,它们仍可以保持自己的状态。
这种存储方式的技巧在于:把对象转化成可以存放在其他媒介上的事物,在需要时,可恢复成常规的、基于RAM的对象。
Java提供了对轻量级持久化的支持,而诸如JDBC和Hibernate这样的机制提供可更加复杂的对在数据库中存储和兑取对象信息的支持。