众所周知,String类型是一种常见的数据引用类型,但是也有它的特殊性,因为String这个类是由final修饰的,这就意味着这个类不能被继承,也不能被重写,并且String定义的值虽然没有看见final 但是依然是常量。
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
String str = new String("哈哈");
String str3 = "嘿嘿";
}
实际上String类定义变量就像第三行代码定义一样,只不过为了方便使用,通常像第4行一样定义。这点在idea中也可以看出。如图所示:
![](https://img-blog.csdnimg.cn/img_convert/9ad8ce4ccdb06d019e1c1471a52951f9.jpeg)
当你的鼠标指针移动到new String时,它会给出一个redundant(多余的)的提示。
问:那么现在问一个问题,下面这个语句中有几个字符串?
String s1 = "哈哈";
String s2 = s1 + "嘿嘿";
答:三个。分别是“哈哈”、“嘿嘿”、“哈哈嘿嘿”。原因就牵扯到String是由final定义的,一旦值被定义就不能改变。由此就可以提出疑问“为什么要将String定义成final ?”
问:为什么要将String定义成final?
答:如果String类不是final 那么就可以被继承,也就意味着子类中可以重写父类的方法, 而String又是Java最基本的一个引用数据类型,一旦方法被重写,运行的时候就意味着我们可以人为的控制JVM的核心代码,那么JDK的安全性无法保障,项目安全性更无法保障,这就相当于在Java随时可以植入一个病毒,太可怕了。所以这里就是典型的牺牲了性能解决了安全性问题,JDK1.0之后,为了能够将String进一步优化,推出了一个新的类,StringBuffer 1.0 和 StringBuilder1.5。简单来说StringBuffer和StringBuilder都是可变的,且StringBuffer 能在多线程的环境中使用,而StringBuilder不能,也正因如此,StringBuilder的运行速度会被StringBuffer要快一些。
如果觉得我的文章对您有帮助的话,请点赞收藏加关注,后续我会继续在别的文章中提到关于JAVA的一些问题,和我的学习心得,感谢您的阅读。