Java中堆和栈的区别在什么地方?来看些实例分析!

180 阅读2分钟
原文链接: mp.weixin.qq.com

堆和栈都是Java用来在RAM中存放数据的地方。

(1)Java的堆是一个运行时数据区,类的对象从堆中分配空间。这些对象通过new等指令建立,通过垃圾回收器来销毁。

(2)堆的优势是可以动态地分配内存空间,需要多少内存空间不必事先告诉编译器,因为它是在运行时动态分配的。但缺点是,由于需要在运行时动态分配内存,所以存取速度较慢。

(1)栈中主要存放一些基本数据类型的变量(byte,short,int,long,float,double,boolean,char)和对象的引用

(2)栈的优势是,存取速度比堆快,栈数据可以共享。但缺点是,存放在栈中的数据占用多少内存空间需要在编译时确定下来,缺乏灵活性。

举例说明栈数据可以共享

String可以用以下两种方式来创建:

  • Stringstr1=newString("abc");

  • Stringstr2="abc";

第一种使用new来创建的对象,它存放在堆中。每调用一次就创建一个新的对象。

第二种是先在栈中创建对象的引用str2,然后查找栈中有没有存放“abc”,如果没有,则将“abc”存放进栈,并将str2指向“abc”,如果已经有“abc”,则直接将str2指向“abc”。

下面用代码说明上面的理论

输出结果为:false

输出结果为:true

因此,用第二种方式创建多个“abc”字符串,在内存中其实只存在一个对象而已。这种写法有利于节省内存空间。同时还可以提高程序的运行速度,因为JVM会自动根据栈中数据的实际情况来决定是否创建新对象。

代码一

思考:分布情况会怎样?

思考:为什么?

s1、s2、s3都是基本类型的局部变量,

ss1、ss2、ss3都是String对象的引用,

所以都在栈区

而"china"是常量,

所以放在常量区

而三个new的对象,

自然就放在堆区

代码二

思考:内存如何分布?

思考:为什么?

(作者)

文章来源 http://www.cnblogs.com/nnngu/p/8300761.html 

(推荐阅读)

java动态代理实现与原理详细分析

详细领悟ThreadLocal变量

MyBatis的底层实现原理!是动态代理的运用~

(完)

java思维导图

长按关注,每天java一下,成就架构师