一、String
1.String 概述
String类
在java.lang 包
下,所以使用的时候不需要导包
String类
代表字符串
,Java程序中的所有字符串文字(例如" abc ")都被实现为此类的实例,也就是说,Java程序中所有的双引号字符串,都是 String 类的对象
2.字符串的特点
- 字符串不可变,它们的
值在创建后不能被更改
- 虽然String的值是不可变的,但是它们
可以被共享
字符串效果上相当于字符数组( char[]),但是底层原理是字节数组( byte[])
3.String 构造方法
4.String 对象的特点
- (1) 通过new 创建的字符串对象,
每一次new都会申请一个内存空间
,虽然内容相同
,但是地址值不同
char[] chs = {'a','b','c'};
String s1 = new String(chs);
String s2 =new String(chs);
上面的代码中,JVM会首先创建一个字符数组,然后每一次new的时候都会有一个新的地址,只不过s1和s2参考的字符串内容是相同的 - (2)以
" ”
方式给出的字符串,只要字符序列相同(顺序和大小写),无论在程序代码中出现几次,JVM都只会建立一个String对象,并在字符串池中维护
5. 字符串的比较
使用 == 作比较
- 基本类型:比较的是
数据值
是否相同 - 引用类型:比较的是
地址值
是否相同
字符串是对象,它比较内容是否相同
,是通过一个方法来实现的,这个方法叫: equals()
public booleanequals(Object anObject)
:将此字符串与指定对象进行比较。由于我们 比较的是字符串对象,所以参数直接传递一个字符串
二、Treeset 集合
1.Treeset集合特点
- 元素有序,这里的顺序不是指存储和取出的顺序,而是按照一定的规则进行排序,具体排序方式取决于构造方法
Treeset(): 根据其元素的自然排序进行排序
Treeset(Comparator comparator): 根据指定的比较器进行排序
- 没有带索引的方法,所以不能使用普通for循环遍历
- 由于是Set集合,所以不包含重复元素的集合
三、自然排序 Comparable 的使用
结论:
- 用TreeSet集合存储自定义对象,无参构造方法使用的是
自然排序
对元素进行排序的 - 自然排序,就是
让元素所属的类实现Comparable接口
,重写compareTo()方法
- 重写方法时,一定要注意排序规则必须按照要求的主要条件和次要条件来写
四、比较器排序 Comparator 的使用
存储学生对象并遍历,创建TreeSet集合使用
带参构造方法
要求:按照年龄从小到大排序,年龄相同时,按照姓名的字母顺序排序
结论:
- 用TreeSet 集合存储自定义对象,带参构造方法使用的是
比较器排序
对元素进行排序的 - 比较器排序,就是
让集合构造方法接收Comparator的实现类对象
,重写compare(To1,To2)方法
- 重写方法时,一定要注意排序规则必须按照要求的主要条件和次要条件来写