Java string
有个同学发了道面试题给我,竟然做错啦,基础啊…自己留个笔记.题目如下
(1)String a1 = “abc”;
(2)String a2 = “abc”;
(3)String b1 = new String(“abc”);
(4)String b2 = new String(“abc”);
System.out.print(a1 == a2); //true
System.out.print(a1.equal(a2)); // true
System.out.print(a1 == b1); //false
System.out.print(a1.equal(b1));//true
System.out.print(b1 == b2);//false
System.out.print(b1.equal(b2));//true
(1),(2)中生成三个对象,变量a1,a2编译器将其放入栈[stack]存储区 , ”abc”是常量,编译器则会将其放入常量储存区,
在执行(1)时,a1放入[stack]存储区,到常量存储区查找是否存在 “abc”, 有则直接a1指向它,没有就将”abc”放入
同理执行(2)时, a2放入[stack]存储区,也同样到常量存储区找”abc”,发现存在”abc”,a2也指向”abc”那块内存
所以,a1==a2 引用的内存地址是一样的,Java无法操作内存,但提供了hashCode(),得到哈希码,这东西就类似于我们的身份证号 , equal只是对比引用对象的内容,倘若地址一样,内容也当然一样了
(3),(4)中生成四个对象, b1,b2同样放入了栈[stack]存储区,使用new关键字则会在堆[heap]中新开辟空间
stack heap
b1 ---------------> abc
b2 ---------------> abc
所以,同上所以
----------------------------------------------------下面是网摘-----------------------------
在JAVA中,有六个不同的地方可以存储数据:
1. 寄存器(register)。这是最快的存储区,因为它位于不同于其他存储区的地方——处理器内部。但是寄存器的数量极其有限,所以寄存器由编译器根据需求进行分配。你不能直接控制,也不能在程序中感觉到寄存器存在的任何迹象。
2. 栈(stack)。位于通用RAM中,但通过它的“堆栈指针”可以从处理器哪里获得支持。堆栈指针若向下移动,则分配新的内存;若向上移动,则释放那些内存。这是一种快速有效的分配存储方法,仅次于寄存器。创建程序时候,JAVA编译器必须知道存储在堆栈内所有数据的
确切大小和生命周期,因为它必须生成相应的代码,以便上下移动堆栈指针。这一约束限制了程序
的灵活性,所以虽然某些JAVA数据存储在堆栈中——特别是对象引用,但是JAVA对象不存储其中。
3. 堆(heap)。一种通用性的内存池(也存在于RAM中),用于存放所以的JAVA对象。堆不同于
堆栈的好处是:编译器不需要知道要从堆里分配多少存储区域,也不必知道存储的数据在堆里存
活多长时间。因此,在堆里分配存储有很大的灵活性。当你需要创建一个对象的时候,
只需要new写一行简单的代码,当执行这行代码时,会自动在堆里进行存储分配。当然,
为这种灵活性必须要付出相应的代码。用堆进行存储分配比用堆栈进行存储存储需要更多的时间。
4. 静态存储(static storage)。这里的“静态”是指“在固定的位置”。
静态存储里存放程序运行时一直存在的数据。
你可用关键字static来标识一个对象的特定元素是静态的,
但JAVA对象本身从来不会存放在静态存储空间里。
5. 常量存储(constant storage)。常量值通常直接存放在程序代码内部,
这样做是安全的,因为它们永远不会被改变。有时,在嵌入式系统中,
常量本身会和其他部分分割离开,所以在这种情况下,可以选择将其放在ROM中
6. 非RAM存储。如果数据完全存活于程序之外,那么它可以不受程序的任何控制,
在程序没有运行时也可以存在。