String类型与常量池(JDK1.8)

String类型是用final进行修饰的,其方法也是被final修饰的

被final修饰的类或者方法其都是不可变的,final修饰变量,变为不可变量,对于对象类型,则是引用不变,修饰的方法,则目的是防止方法中五一的修改会影响到方法的调用,final修饰的类,为不可继承类。

小注:String是f通过char型的类型进行保存字符串的,对String类型的任何操作都不会影响到原来的String对象,所有的改变都会创建新的对象

常量赋值:其会先在字符串常量池中(只有一份)

        String s1="a";
        String s2="b";
        String s3="c";
        String s5="abc"
        String s4=s1+s2+s3;
        String s6="a"+"b"+"c";
        System.out.println(s4==s5);
        System.out.println((s4==s6);

结果为false;

对于直接做“+”运算的两个字符串对象,并不会放入到字符串常量池中,而是直接的把运算后的结果放入到字符串常量池中,如上中的String s6="a"+"b"+"c";会直接的生成abc字符串对象, String s4=s1+s2+s3;该句就是被java编译器进行优化,实际上是使用了StringBuilder调用append()方法进行拼接字符串,然后转变为String类型实现,实际上也是开辟了新的内存空间。

 

此时对全局字符串池:

全局字符串池里的内容是在类加载完成,经过验证,准备阶段之后在堆中生成字符串对象实例,然后将该字符串对象实例的引用值存到string pool中(记住:string pool中存的是引用值而不是具体的实例对象,具体的实例对象是在堆中开辟的一块空间存放的。)。 在HotSpot VM里实现的string pool功能的是一个StringTable类,它是一个哈希表,里面存的是驻留字符串(也就是我们常说的用双引号括起来的)的引用(而不是驻留字符串实例本身),也就是说在堆中的某些字符串实例被这个StringTable引用之后就等同被赋予了”驻留字符串”的身份。这个StringTable在每个HotSpot VM的实例只有一份,被所有的类共享。

String与常量池(JDK1.8) - 凉月缘 - 博客园(参考)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值