Java中Heap和Stack简介说明

下文笔者讲述Heap和Stack简介说明,如下所示
Heap和Stack简介 
栈(stack)与堆(heap):
   是Java在内存中存放数据的地方
 在Java中自动管理栈和堆
 

栈(stack)与堆(heap)优缺点比较

 栈
 
栈的优点:
   存取速度比堆要快
   仅次于直接位于CPU中的寄存器
   数据可以共享
栈的缺点:
   存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。
 

堆 
堆的优点:
   可以动态地分配内存大小
    生存期也不必事先告诉编译器
    由Java的垃圾收集器会自动回收垃圾数据

堆的缺点:
   需在运行时动态分配内存,存取速度较慢

Java中数据类型存储位置
基本类型(primitive types)

 

基本数据类型共8种:
 int, short, long, byte, float, double, boolean, char
  如:
    int a = 8;
    这里指向int类型的引用,指向8的字面值
    当程序块退出后,字面值消失

栈的数据都是共享
如:
 

int a = 8; 
  int b = 8;

编译器先处理int a = 8;
1.在栈中创建一个变量为a的引用,然后查找有没有字面值为8的地址
   如果没有找到,就开辟一个存放8这个字面值的地址
    然后将a指向8的地址
2.当此时处理int b = 8
   在创建完b的引用变量后
  由于在栈中已经有8这个字面值
  便将b直接指向8的地址
此时就出现了a与b同时均指向8的情况

注意事项:
    字面值的引用与类对象的引用不同
    如果两个类对象的引用同时指向一个对象,当一个对象引用变量修改了这个对象的内部状态,那么另一个对象引用变量也即刻反映出这个变化
    但是字面值的引用来修改其值,不会导致另一个指向此字面值的引用的值也跟着改变的情况
    如上例,我们定义完a与b的值后,再令a=100,则b不会等于100,还是等于8
      在编译器内部,遇到a=100时,它就会重新搜索栈中是否有100的字面值,如果没有,重新开辟地址存放100的值;如果已经有了,则直接将a指向这个地址,所以a值的改变不会影响到b的值。

 
 包装类型 
 

包装类型:
    Integer, String, Double等将相应的基本数据类型包装起来的类
     这些类数据全部存在于堆中
    Java代码中使用new()语句来显示地告诉编译器,在运行时才根据需要动态创建

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值