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类,以提高程序效率。(反复创建占用内存太多了,总之你以后这样做就行!)

  • 相关阅读:
    8月7号的练习:HDU 1069&&POJ 1636&&HDU 1031&&HDU 1051&&HDU 1551
    8月8号的线段树:HDU 1754&&POJ 3264&&HDU1166
    8月6号的题目:HDU 1003&& POJ 1050&&HDU 1800&&HDU 2036&& POJ 1088(记忆化搜索)
    HDU 1052
    背包问题九讲:
    一个人的旅行 HDU 2066 &&HDU Today HDU 2112
    8月3号的LCS,LIS,LICS:Longest Ordered Subsequence&&Common Subsequence&&Greatest Common Increasing Subsequence
    那些操蛋的搜索题目:逃离迷宫&&哈密顿绕行世界问题
    C语言栈调用机制初探
    linux0.11改进之四 基于内核栈的进程切换
  • 原文地址:https://www.cnblogs.com/webapplee/p/3801174.html
Copyright © 2011-2022 走看看