1.栈(stack):由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。
2.堆(heap):由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收 。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表。
答案:1.true,当使用基本类型定义一个变量的时候,java就在栈中为这个变量分配内存空间,所以当num1和num2作比较的时候,因为num1已经在栈中有这个数据了,所以num不需要再创建一个值了,直接指向10所在的地址就可以了,所以为true。只要是基本类型只需要比较数值就好了。
2.true,String是一个引用类型,对于引用类型来说程序在运行的时候会创建一个字符串缓冲池,当个使用s2=“51ctofx.com”这个表达式创建一个字符串的时候,程序会先找缓冲池中是否已经存在这样一个数据,如果有可以直接使用,所以在s2创建时,s1已经创建好了,直接使用就可以了,所以为true。
3.true,复合数据中equal,(String、Integer、date)等重写了equal比较的是内容,没有重写equal的,比较的还是内存地址
4.false复合类型用“==”比较的是他们在内存中的地址,所以为false
5.true,同3,复合类型equals比较的是内容。
6.equal比较的是内存地址,new一次就新建了一个地址,所以为false
7.true,st指向的是student所指向的地址,没有创建新的对象,所以为true。
3.JVM中的堆和栈
堆(heap)
用于存放所有的Java对象。
栈(stack)
用于存放基本类型的数据和对象的引用。
当在一段代码块定义一个变量时,Java就在栈中为这个变量分配内存空间,当超过变量的作用域后,Java会自动释放掉为该变量所分配的内存空间, 该内存空间可以立即被另作他用。 所以尽量使用基本类型的变量.
堆内存用来存放由 new创建的对象和数组。 由Java虚拟机的自动垃圾回收器来管理。当然一个对象的创建并不是那么简单的,关于对象的创建过程一般是从new指令开始的,JVM首先对符号引用进行解析,如果找不到对应的符号引用,那么这个类还没有被加载,因此JVM便会进行类加载过程。符号引用解析完毕之后,JVM会为对象在堆中分配内存,HotSpot虚拟机实现的JAVA对象包括三个部分:对象头、实例字段和对齐填充字段,其中要注意的是,实例字段包括自身定义的和从父类继承下来的(即使父类的实例字段被子类覆盖或者被private修饰,都照样为其分配内存)。相信很多人在刚接触面向对象语言时,总把继承看成简单的“复制”,这其实是完全错误的。JAVA中的继承仅仅是类之间的一种逻辑关系,唯有创建对象时的实例字段,可以简单的看成“复制”。
为对象分配完堆内存之后,JVM会将该内存(除了对象头区域)进行零值初始化,这也就解释了为什么JAVA的属性字段无需显示初始化就可以被使用,而方法的局部变量却必须要显示初始化后才可以访问。最后,JVM会调用对象的构造函数,当然,调用顺序会一直上溯到Object类。至此,一个对象就被创建完毕,此时,一般会有一个引用指向这个对象。在JAVA中,存在两种数据类型,一种就是诸如int、double等基本类型,另一种就是引用类型,比如类、接口、内部类、枚举类、数组类型的引用等。
4、equal和“==”的区别?
基本数据类型用==比较时,比较的是实际值
复合类型时,==比较的使它们在内存中 的存放地址
复合类型中(String,Integer,date)等重写了equal方法的,比较的是内容,没有重写equal的,还是比较的内存地址
StringBuffer和StringBuilder比较特殊,比较的都是他们的内存地址