Java字面常量与常量池

Java字面常量与常量池Java 中的字面常量 区别于 final 创建的有名常量 通常会保存在常量池中 常量池可以理解为像堆一样的内存区域

欢迎大家来到IT世界,在知识的湖畔探索吧!

Java中的字面常量(区别于final创建的有名常量)通常会保存在常量池中,常量池可以理解为像堆一样的内存区域。但是常量池有一个特性就是,如果常量池中已存在该常量将不会再次为该常量开辟内存

还是看个程序:

package reverse; public class Reverse { public static void main(String[] args) { String s1="张汉青"; String s2="张汉青"; String s3=new String("张汉青"); System.out.println(""+(s1==s2)); System.out.println(""+(s1==s3)); System.out.println("-----------------------"); Integer I=Integer.valueOf(5); Integer J=Integer.valueOf(5); Integer Q=5; System.out.println(""+(I==J)); System.out.println(""+(J==Q)); System.out.println("-----------------------"); Integer k=Integer.valueOf(128); Integer g=Integer.valueOf(128); System.out.println(""+(k==g)); System.out.println("-----------------------"); Double d=12.5; Double e=12.5; System.out.println(""+(d==e)); } }

欢迎大家来到IT世界,在知识的湖畔探索吧!

输出结果为:

Java字面常量与常量池
欢迎大家来到IT世界,在知识的湖畔探索吧!

s1所引用的字符串对象是字面常量,会存储在常量池,

s2所引用的字符串对象也是字面常量,而且常量“张汉青”在常量池中出现过,所以Java并不会为s2所引用的对象开辟新的内存而是让s2直接引用之前存在的”张汉青”

内存中的模拟:

Java字面常量与常量池

所以s1==s2为true;

s3是用new创建的,该对象的内存应该位于堆;

所以s1==s3为false

除了String类的字面常量会用到常量池,Java基础类型的包装类也会用到常量池,包括Byte,Short,Integer,Long,Character,Boolean;

所以I==J==Q为true

要注意Byte,Short,Integer,Long,Character这5种整型的包装类也只是在对应值小于等于127时才可使用对象池,也即对象不负责创建和管理大于127的这些类的对象

所以k==g为false

另外double和float并没有实现常量池技术。

所以d==e为false

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://itzsg.com/117484.html

(0)
上一篇 6天前
下一篇 6天前

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们YX

mu99908888

在线咨询: 微信交谈

邮件:itzsgw@126.com

工作时间:时刻准备着!

关注微信