zoukankan      html  css  js  c++  java
  • [Java_kaikeba]java中堆和栈的区别(对象变量的理解)

    .堆和栈都是java用来在RAM中存放数据的地方。与C++不同,java自动管理堆栈,
          程序员不能直接设置堆栈。
    .区别
          1、
          .栈中存放基本数据类型变量(int、float、boolean、char...)和对象句柄
          .堆中存放对象数据类型或者说类对象数据类型
          (String、基本数据类型对应的类类型(Integer、Double...))
          2、
          .栈的存取速度比较快,仅次于寄存器,栈数据可以共享。但栈数据的大小和
          生存期必须是确定的,缺乏灵活性。
          .堆中的数据在*运行时*动态的分配内存,存取速度慢,有垃圾回收机制负责
          堆中的对象通过new、newarrary、anewarray和multianewarray等指令建立
    ****************************************************************************************************
    .超级重要的实例
    例一
          int a = 3;
          int b = 3;
          .在栈中先创建一个变量为a的引用,再查找栈中是否有3这个值,若没有就把3
          存放进来,然后将a指向3.
          .接着,创建变量为b的引用,因为栈中已经有3所以直接将b指向3.
          .这样a、b同时均指向3的情况
          int a = 4;
          .接着把a指向4(4在另一个内存块中),但是a的改变不会影响到b的值
          .这样做有利于节省空间
          ***而对于堆中的对象引用,多个同时指向时,一个对象引用变量修改了
          这个对象的内部状态,会影响到另一个对象引用变量(动态)
    例二
          String是一种特殊的包装类
          String str = new String("abc");
          String str = "abc";
          第一种,在堆中new新对象,每new一次创建一个新对象!
          第二种,在栈中,先查找后指向,与基本数据类型一致
    例三
          ****比较类里面的数值是否相等,用equals()方法;(无关)
          ****测试类的引用是否指向同一对象时,用==;(有关)
          
          String str1 = "abc";
          String str2 = "abc";
          System.out.println(str1==str2); //true
          str1和str2指向同一对象

     String str1 = new String("abc");
          String str2 = new String("abc");
          System.out.prinln("str1==str2"); //flase
          new方式生成了不同的对象,每次生成一个,应该用equals()方法比较
          ****注意:String str = "abc";不要想当然的认为:创建了string类的对象!
          可能没有创建只是指向了先前已经存在的一个对象。只有new()方法才能
          保证每次都创建一个新的对象。
    .由于String类型的immutable(不可变)性质,当String变量需要经常变换其值时,应该考虑使用
          StringBuffer类,以提高程序效率。(反复创建占用内存太多了,总之你以后这样做就行!)

  • 相关阅读:
    Hihocoder 1275 扫地机器人 计算几何
    CodeForces 771C Bear and Tree Jumps 树形DP
    CodeForces 778D Parquet Re-laying 构造
    CodeForces 785E Anton and Permutation 分块
    CodeForces 785D Anton and School
    CodeForces 785C Anton and Fairy Tale 二分
    Hexo Next 接入 google AdSense 广告
    如何统计 Hexo 网站的访问地区和IP
    Design and Implementation of Global Path Planning System for Unmanned Surface Vehicle among Multiple Task Points
    通过ODBC接口访问人大金仓数据库
  • 原文地址:https://www.cnblogs.com/webapplee/p/3801174.html
Copyright © 2011-2022 走看看