------<a href="http://www.itheima.com" target="blank">Java培训、Android培训、iOS培训、.Net培训</a>、期待与您交流-----
一、Set
1、Set概述
特点:Set中的元素无序,不可以存放重复元素
|--HashSet:数据结构是哈希表。线程是非同步的。
保证元素唯一性的原理:判断元素的hashCode值是否相同。
如果相同,还会继续判断元素的equals方法,是否为true。
|--TreeSet:可以对Set集合中的元素进行排序。
底层数据结构是二叉树。
保证元素唯一性的依据:compareTo方法return 0.
TreeSet排序的第一种方式:让元素自身具备比较性(默认顺序)。
元素需要实现Comparable接口,覆盖compareTo(Object obj)方法。
这种方式也称为元素的自然顺序,或者叫做默认顺序。
当主要条件相同时,一定判断一下次要条件
TreeSet的第二种排序方式。
当元素自身不具备比较性时,或者具备的比较性不是所需要的。
这时就需要让集合自身具备比较性。在集合初始化时,就赋予其比较方式。
方式:定比较器,将比较器对象作为参数传递给TreeSet集合的构造函数
定义比较器方式:
定义一个类,实现Comparator接口,
覆盖compare(Object o1,Object o2)方法
注意:当一个对象被存储进HashSet集合中以后,就不能修改这个对象了,如若修改则这个对象的哈希就会改变,它在该集合中的存储位置就会改变,这是就找不到这个对象了,也就无法对其进行删除或者其他操作这种情况称作:内存泄露。
TreeSet小练习
需求:往TreeSet集合中存储自定义对象学生。想按照学生的年龄进行排序。
2、TreeSet的第一种比较方式
运行结果为:
3、TreeSet的第二种比较方式
运行结果为:
二、泛型
泛型:JDK1.5版本以后出现的新特性。用于解决安全问题,是一个类型安全机制。
1、好处
1、将运行时期出现问题ClassCastException,转移到了编译时期。,
方便于程序员解决问题。让运行时问题减少,安全。,
2、避免了强制转换麻烦。
泛型格式:通过<>来定义要操作的引用数据类型。
在使用java提供的对象时,什么时候写泛型呢?
通常在集合框架中很常见,只要见到<>就要定义泛型。其实<> 就是用来接收类型的。
当使用集合时,将集合中要存储的数据类型作为参数传递到<>中即可。
2、泛型类
泛型类定义的泛型,在整个类中有效。类的类型一经确定则所有方法都是此类型。
什么时候定义泛型类?
当类中要操作的引用数据类型不确定的时候,就用泛型类。
早期定义Object来完成扩展。现在定义泛型来完成扩展。
代码实例:
3、泛型方法
为了让不同方法可以操作不同类型,而且类型还不确定,那么可以将泛型定义在方法上。这样方法的类型就和类的类型不一样了。
3.1、静态泛型方法
静态方法不可以访问类上定义的泛型。
如果静态方法操作的应用数据类型不确定,可以将泛型定义在方法上。
代码示例:
4、泛型接口
代码示例:
5、泛型的高级应用(泛型的限定)
当类型不确定的时候可以用通配符?表示。也可以理解为占位符。
好处:提高扩展性。弊端:不能使用类型特有方法。
5.1上限:格式:? extendsE: 可以接收E类型或者E的子类型。
5.1下限:格式:? superE: 可以接收E类型或者E的父类型。
注:能看的懂即可。
本文详细介绍了Java中的Set集合,包括HashSet和TreeSet的特点及元素唯一性的原理。特别讨论了TreeSet的两种排序方式,即元素自然顺序排序和定制比较器排序。此外,文章还深入探讨了Java泛型的概念、好处,以及泛型类、泛型方法、泛型接口的使用,并展示了泛型的高级应用,如泛型限定(上限和下限)。
441

被折叠的 条评论
为什么被折叠?



