码迷,mamicode.com
首页 > 编程语言 > 详细

java-oop 堆栈

时间:2017-06-22 23:56:21      阅读:333      评论:0      收藏:0      [点我收藏+]

标签:存在   释放   编译   运行时   访问   运行   告诉   垃圾   类型   

1  head和stack有什么区别

  栈(stack) 和堆(head)都是在内存中存放数据的地方,二者的区别在于:

  1 栈存放基本类型变量和对象应用,当超过作用域后释放,堆存放new出来额对象和数组;

  2 堆可以动态的分配内存的大小,神存期也不必先告诉编译器;java的垃圾回收器会自动回收这些没有用的数据,而存在栈中的数据大小和生存期必须是确定的,缺乏灵活性。栈的存取速度比堆要快,仅次于直接位于cpu的寄存器。堆由于要在运行时动态分配内存,存取速度慢;

  3  栈数据可以共享,如字面量3  等 ; 堆不可以

  4  栈是一种线性集合,其添加和删除元素额操作应该在同一段完成,栈按照后进先出的方式进行处理,  栈地址是连续的,可以随机访问。

java-oop 堆栈

标签:存在   释放   编译   运行时   访问   运行   告诉   垃圾   类型   

原文地址:http://www.cnblogs.com/leige2017/p/7067690.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!