background image

因为它们永远不会被改变。有时,在嵌入式系统中,常量本身会和其他部分分割离开,所
以在这种情况下,可以选择将其放在 ROM 中
6. 非 RAM 存储。如果数据完全存活于程序之外,那么它可以不受程序的任何控制,在程
序没有运行时也可以存在。
就速度来说,有如下关系:
    

 

寄存器 < 

 

堆栈 <   

堆 < 其他

『上面这段话摘取之《Thinking in Java》』

在这里,主要要说下堆与堆栈的关系:

      堆:堆是 heap,是所谓的动态内存,其中的内存在不需要时可以回收,以分配给新的
内存请求,其内存中的数据是无序的,即先分配的和随后分配的内存并没有什么必然的
位置关系,释放时也可以没有先后顺序。一般由使用者自由分配,malloc 分配的就是堆,
需要手动释放。

      堆栈:就是 STACK。实际上是只有一个出入口的队列,即后进先出(First     In     Last 
Out),先分配的内存必定后释放。一般由,由系统自动分配,存放存放函数的参数值,
局部变量等,自动清除。

还有,堆是全局的,堆栈是每个函数进入的时候分一小块,函数返回的时候就释放了,
静态和全局变量,new     得到的变量,都放在堆中,局部变量放在堆栈中,所以函数返
回,局部变量就全没了。

其实在实际应用中,堆栈多用来存储方法的调用。而对则用于对象的存储。

      

 JAVA 中的基本类型,其实需要特殊对待。因为,在 JAVA 中,通过 new 创建的对象存

“ ”

储在 堆 中,所以用 new 创建一个小的、简单的变量,如基本类型等,往往不是很有效。
因此,在 JAVA 中,对于这些类型,采用了与 C、C++相同的方法。也就是说,不用 new 来

” “

“ ”

创建,而是创建一个并非是 引用 的 自动 变量。这个变量拥有它的 值 ,并置于堆栈中,
因此更高效