标签:存储 hibernate 数据 常用 事物 灵活 完全 代码 基于
用引用操作对象。
创建了一个引用,需要进行初始化(与事物进行关联),才能正常使用。
new将引用于对象进行关联
对象存储到什么地方?
程序运行时,对象是怎么进行放置安排的呢?特别是内存是怎么分配的呢?对这些方面的了解会对你有很大的帮助。
有五个不同的地方可以存储数据:
1、寄存器。这是最快的存储区,因为它位于不同于其他存储区的地方————处理器内部。但是寄存器的数量极其有限,所以寄存器根据需求进行分配。你不能直接控制,也不能在程序中感觉到寄存器存在的任何迹象
2、堆栈。位于通用RAM(随机访问存储器)中,但通过堆栈指针可以从处理器哪里获得直接支持。堆栈指针若向下移动,则分配新的内存,若向上移动,则释放那些内存。这是一种快速有效的分配存储方法,仅次于寄存器。创建程序时,Java系统必须知道存储在堆栈内所有项的确切生命周期,以便于上下移动堆栈指针。这一约束限制了程序的灵活性,所以虽然某些java数据存储于堆栈中————特别是对象引用,但是java对象并不存储于其中。
3、堆。一种通用的内存池(也位于RAM区),用于存放所有的java对象。堆不同于堆栈的好处是:编译器不需要知道存储的数据在堆里存活多长时间。因此在堆里分配存储有很大的灵活性。当需要一个对象时,只需用new写一行简单的代码,当执行这行代码时,会自动在堆里进行存储分配。当然,为这种灵活性必须要付出相应的代价:用堆进行存储分配和清理可能比用堆栈进行存储分配需要更多的时间(如果java确实可以在栈中创建对象)
4、常量存储。常量值通常直接存放在程序内部代码,这样做是安全的,因为它们永远不会改变。有事,在嵌入式系统中,常量本身会和其他部分分隔开来,所以在这种情况下,可以选择将其存放在ROM(只读存储器)中。(这种存储区的一个例子是字符串池,所有字面常量字符串和具有字符串值的常量表达式都自动是内存限定的,而且会置于特殊的静态存储区中)
5、非RAM存储。如果数据完全存活于程序之外,那么它可以不受程序的任何控制,在程序没有运行时也可以存在。两个基本的例子就是流对象和持久化对象。这种存储方式的技巧在于:把对象转换成可以存放在其他媒介上的事务,在需要的时候,可以恢复成常规的、基于RAM的对象。Java提供了对轻量级持久化的支持,而诸如JDBC和hibernate这样的机制提供了更加复杂的对在数据库中存储和读取对象信息的支持。
特例:基本数据类型
在程序设计中经常用到一系列类型,它们需要特殊对待。可以把它们想像称为“基本数据类型”。之所以特殊对待,是因为new将对象存储在“堆”里,故new创建一个对象————特别是小的、简单的对象,往往不是很有效。因此对于这些类型,Java采取和C和C++相同的方法。也就是说,不用new来创建对象,而是创建一个并非是引用的“自动”变量。这个变量直接存储“值”,并置于堆栈中,因此更加高效。
标签:存储 hibernate 数据 常用 事物 灵活 完全 代码 基于
原文地址:http://www.cnblogs.com/aigeileshei/p/7182606.html