JVM基础:深入学习JVM堆与JVM栈( 三 )

为什么要把JVM堆和JVM栈区分出来呢?JVM栈中不是也可以存储数据吗?

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

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

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

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

推荐阅读