Java之堆和栈的区别

一.最近在回首Java基础,发现了一个挺有意思的概念,简言以述之。

A.共同点:堆和栈都是Java中常用的存储结构,都是内存中存放数据的地方。

B.不同点:

1.堆 stack:是一个临时的,动态创建的概念,多数由是new 出来的(对象或数组)。

作用:主要用于存放对象,存取速度慢,可以运行时动态分配内存,生存期不需要提前确定。

示例:String s = new String("hello");

数据共享:否 。
由于new出来的时间和生命周期不能确定,故此
String s1 = new String(“hello”);
String s2 = new String(“hello”);
s1.equals(s2); 为true,可以理解为s1和s2的值是一样的,都是hello。
s1==s2; 为false,可以理解为s1和s2是分别指向不同的地址(创建的时间和生命周期不一致)。

2.栈 heap:是一个生命周期固定的,大小确定的概念。

 作用:主要用来执行程序,存取速度快,大小和生存期必须确定,缺乏灵活性。

 示例:String s = "hello";

数据共享:是 。
由于栈中的数据大小和生命周期是固定的,故此:
String s1 = “hello”;
String s2 = “hello”;
s1.equals(s2); 返回true
s1==s2; 返回true
首先它会在栈中创建一个变量为s1的引用,然后查找有没有字面值为hello的地址,没找到,就开辟一个存放hello这个字面值的地址,然后将s1指向hello的地址。接着处理String s2=”hello”;在创建完s2的引用变量后,由于在栈中已经存在hello这个字面值,便将s2直接指向hello的地址。这样,就出现了s1与s2同时指向hello这个地址的情况。

三.随手分享,喜欢的朋友可以关注微信公众号MiHomes,后续会有更多更好的博客推送给您。

另:欢迎指出不足,会进行更正

    原文作者:MiHomes
    原文地址: https://www.jianshu.com/p/e64ec660fb79
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞