JAVA中堆和栈的区别

上一篇 / 下一篇  2014-05-28 10:10:19 / 个人分类:学习

本人小白,自学java,觉得有一些基础概念对于将来性能测试会有帮助。谢谢度娘,以下是一些民间高手总结的,精炼到位

谢谢“小闷暴走”
第一,从软件设计的角度看,栈代表了处理逻辑,而堆代表了数据。这样分开,使得处理逻辑更为清晰。
分而治之的思想。这种隔离、模块化的思想在软件设计的方方面面都有体现。

第二,堆与栈的分离,使得堆中的内容可以被多个栈共享(也可以理解为多个线程访问同一个对象)。
这种共享的收益是很多的。一方面这种共享提供了一种有效的数据交互方式(如:共享内存),
另一方面,堆中的共享常量和缓存可以被所有栈访问,节省了空间。

第三,栈因为运行时的需要,比如保存系统运行的上下文,需要进行地址段的划分。
由于栈只能向上增长,因此就会限制住栈存储内容的能力。而堆不同,堆中的对象是可以根据需要动态增长的,
因此栈和堆的拆分,使得动态增长成为可能,相应栈中只需记录堆中的一个地址即可。

第四,面向对象就是堆和栈的完美结合。其实,面向对象方式的程序与以前结构化的程序在执行上没有任何区别。
但是,面向对象的引入,使得对待问题的思考方式发生了改变,而更接近于自然方式的思考。当我们把对象拆开,
你会发现,对象的属性其实就是数据,存放在堆中;而对象的行为(方法),就是运行逻辑,放在栈中。
我们在编写对象的时候,其实即编写了数据结构,也编写的处理数据的逻辑。不得不承认,面向对象的设计,确实很美。

谢谢“aliouswang

例如 String str = new String("test");
这条语句,它的执行过程是先在堆上new 了一个值为"test"的String对象,然后栈上又新建一个str
来指向上面新建的"test"对象,即str是"test"的引用。
所以Java中对象的新建都是在堆上进行的,对象的引用一般都是在栈上。一般每个方法的调用都会独立有一个栈来保存str这样的对象的引用变量,在方法返回后,栈会清空,所以引用变量会被清空掉,这是堆上的对象,如果没有其他的引用变量引用它,就会被Gc在某个合适的时候gc掉。
上面说的就是栈和堆的作用在程序执行过程中。更深的理解,还需你在工作学习中不断去用它们才能体会得到。纯手打,希望可以帮到你,谢谢采纳。
谢谢“若amp惜”
堆是由垃圾回收来负责的,堆的优势是可以动态地分配内存大小,生存期也不必事先告诉编译器,因为它是在运行时 动态分配内存的,Java的垃圾收集器会自动收走这些不再使用的数据。但缺点是,由于要在运行时动态分配内存,存取速度较慢。

栈的优势是,存取速度比堆要快,仅次于寄存器,栈数据可以共享。但缺点是,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。栈中主要存放一些基本类 型的变量(,int, short, long, byte, float, double, boolean, char)和对象句柄。
主要看作用就知道了。

另外还有一位高手,“龙v站”的博客,有更加深入的关于JVM中,堆、栈、方法区的介绍,
太经典了!
链接:http://www.cnblogs.com/kkcheng/archive/2011/02/25/1964521.html

TAG:

 

评分:0

我来说两句

我的栏目

日历

« 2024-04-28  
 123456
78910111213
14151617181920
21222324252627
282930    

数据统计

  • 访问量: 17743
  • 日志数: 12
  • 建立时间: 2014-05-21
  • 更新时间: 2014-06-03

RSS订阅

Open Toolbar