String类的概述
-
String类:代表字符串 。是常量,用一对 “” 引起来。它们的值在创建之后不能更改。
-
String是一个final类,不可被继承。
-
String实现了Serializable接口:表示字符串是支持序列化的。
实现了Comparable接口:表示String可以比较大小。 -
String内部定义了 final char value[] 用于存储字符串数据。
-
String:代表不可变的字符序列。简称:不可变性。
String的不可变性
-
String:代表不可变的字符序列。简称:不可变性。
体现: 1. 当对字符串重新赋值时,不能修改原字符串(即不能对原本的value[]进行重新赋值),而是重新指定内存区域再赋值。 2. 当对现有的字符串进行连接操作时,不能使用原有的value[]进行连接并赋值,也需要重新指定内存区域赋值。 3. 当调用String的replace()方法修改指定字符或字符串时,不能使用原有的value[]进行赋值,也需要重新指定内存区域赋值。 结论:原本的字符串都没变,是通过开辟新空间的方式进行字符串的赋值、连接、替换等操作。
- 通过字面量的方式(不new的方式)对字符串赋值,此时的字符串值声明在
字符串常量池
中。
String str1 = "abc"; // 字面量的定义方式
- 字符串常量池中不会存储相同内容的字符串。 所以如果两个字面量方式赋值的字符串值相等,则地址值相等。
String str1 = "abc";
String str2 = "abc";
System.out.println(str1 == str2); // true
String的两种实例化方式对比
方式一:通过字面量
定义的方式
字符串常量存储在方法区中的字符串常量池里,目的是共享。
字面量方式定义的String是常量,常量在常量池里。
方法二:通过 new + 构造器
的方式
字符串非常量对象存储在堆中。
new出来的是对象,对象在堆中。
PS:
如果两对象属性相等,则地址值也相等。
如果对象中某属性的值和字符串值相等,则该属性的地址和字符串地址相等,都指向方法区常量池中的那个值。
//通过字面量定义的方式:此时的s1和s2的数据javaEE声明在方法区中的字符串常量池中。
String s1 = "javaEE";
String s2 = "javaEE";
//通过new + 构造器的方式:此时的s3和s4保存的地址值,是数据在堆空间中开辟空间以后对应的地址值。
String s3 = new String("javaEE");
String s4 =