开启Java的墓穴05 — String、字符串、Treeset集合、Comparable排序、Comparator排序

一、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)方法
  • 重写方法时,一定要注意排序规则必须按照要求的主要条件和次要条件来写
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值