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的实例只有一份,被所有的类共享。