Java基础中,通过new创建的对象存储在堆内存中,8大基本类型short,int,char,byte,boolean,float,double,long和对象的引用变量存储在栈内存中,那么具体是如何存储的?
栈:当在一段代码块定义一个变量时,Java就在栈中为这个变量分配内存空间,当该变量退出该作用域后,Java会自动释放掉为该变量所分配的内存空间,该内存空间可以立即被另作他用。
如:int a =1;int b =1;
首先在栈中建立一个a的引用,在栈中寻找值1的地址,若发现该地址,则将引用指向该地址,若没有则在栈中开辟新的空间存储1,很多地方用堆栈来表示栈,看的我云里雾里,也就是堆栈=栈=stack。
(个人理解如下:若有差错请帮忙修改)
为int b 新建一个引用。发现1这个值已经存在地址空间,将b指向该地址。
以上为栈内存的分配,还有一个问题当a和b同时指向同一个地址,为什么改变a不会影响b呢?如a=8;主要是会在栈中重新寻找8这个值的地址,若没有则从新开辟空间,然后将a的引用指向地址8。固两个引用不改变。
堆内存分配:
那么String a = "test";与String b = new String("hello");有什么不同?
String a = "test";中的"test"为存储在常量池中
String b = new String("hello");会首先创建一个引用b,然后再堆栈创建一个new String("hello");,再该过程中,会再产量池中寻找有没有对应的hello对象,如果有则在堆中拷贝一个该对象的拷贝对象。如果没有则在产量池中首先创建一个hello对象。
固在该过程中可能产生1个或是2个新对象。
其中String的 intern()方法为返回其常量池中对象的方法,当一个String实例str调用intern()方法时,Java 查找常量池中是否有相同Unicode的字符串常量,如果有,则返回其的引用,如果没有,则在常量池中增加一个Unicode等于str的字符串并返回它的引用
String的对象引用根据是常量池的引用和堆中的引用,会产生不同的结果。