什么就不解释了,自己查查书吧!
java 中,stack 存放基本数据类型和对象的引用.但对象本身
放在heap中。
heap存放new产生的数据

解决方案 »

  1.   

    2) 堆栈。驻留于常规RAM(随机访问存储器)区域,但可通过它的“堆栈指针”获得处理的直接支持。堆栈指针若向下移,会创建新的内存;若向上移,则会释放那些内存。这是一种特别快、特别有效的数据保存方式,仅次于寄存器。创建程序时,Java编译器必须准确地知道堆栈内保存的所有数据的“长度”以及“存在时间”。这是由于它必须生成相应的代码,以便向上和向下移动指针。这一限制无疑影响了程序的灵活性,所以尽管有些Java数据要保存在堆栈里——特别是对象句柄,但Java对象并不放到其中。
    (3) 堆。一种常规用途的内存池(也在RAM区域),其中保存了Java对象。和堆栈不同,“内存堆”或“堆”(Heap)最吸引人的地方在于编译器不必知道要从堆里分配多少存储空间,也不必知道存储的数据要在堆里停留多长的时间。因此,用堆保存数据时会得到更大的灵活性。要求创建一个对象时,只需用new命令编制相关的代码即可。执行这些代码时,会在堆里自动进行数据的保存。当然,为达到这种灵活性,必然会付出一定的代价:在堆里分配存储空间时会花掉更长的时间!
      

  2.   

    java中将变量分为基本类型和对象类型。
    在堆栈(stack)中,java保存的是基本类型的变量地址,同时保存了对象类型地址的引用。
    与栈相比,堆(heap)是一个物理地址不连续的一片空间,用于保存对象类型的变体的具体信息。java的垃圾回收就是,栈中有对象的引用,而它指向的堆中的对象已不存在。这时,就应该释放堆里的空间。唉,打这么写字好辛苦的说…… 希望对你有帮助吧。
      

  3.   

    楼上的错误一堆
    在 stack 中保存的是基本类型的数据本身,和引用类型对象的地址(Java 中叫引用,C++ 中叫指针)。堆是连续空间,但是分配给每个对象的空间可以是不连续的。它保存了所有 new 产生的对象。
    gc 是当对于堆中的某个对象,无法从栈上的任何一个引用跟踪(trace)得到,则认为这个堆空间已经没有用,标记为回收。