集合类型,泛型

集合:

集合可以分为:Collection接口(单列)和Map接口(双列)

Collection:下面又有两个接口分别是List和Set。

List:list接口(继承了 Collection)(常用子类:ArrayList(底层是数组), LinkedList(底层是双链表)),list:有序集合(也称为序列),该界面的用户可以精确控制列表中每个元素的插入位置。用户可以通过整数索引(列表中的位置)访问元素,并搜索列表中的元素。与set不同,列表通常允许重复的元素

特征:1.有序:存储和取出的元素顺序一致。2.可重复:存储的元素可以重复

Set:Set接口的常用子类和List相似分别是HashSet(底层数据结构是哈希表)和LinkedHashSet(底层是哈希表和链表实现的Set接口,具有可预测的迭代次序),LinkedHashSet由哈希表保证元素唯一,也就是说没有重复的元素,由链表保证元素有序,也就是说元素的存储和取出顺序是一致的,而HashSet只保证元素的唯一性。

还有一类是TreeSet:TreeSet<E>(间接实现Set)(使用基础类型的时候要用对应的包装类)

元素有序,这里的顺序不是指存储和取出的顺序,而是按照一定的规则进行排序,具体排序方式取决于构造方法:

1.TreeSet():是根据其元素的自然排序进行排序。

2.TreeSet(Comarator comparator):根据指定的比较器进行排序

List和Set的区别:1.Set没有索引的方法,不能使用普通for循环遍历,而List有可以使用三种遍历方式;2.List不能保证元素的唯一性,而Set可以保证。

Map:Interface Map<K,V> K:键的类型 ; V:值的类型;将键映射到值的对象,不能包含重复的键,每个键可以映射到最多一个值。

Map的实现:

1.具体的实现类HashMap,而Hash会保证键的唯一性,HashMap是一个“链表散列”的数据结构,即数组和链表的结合体;可以通过数组数据结构和指针(引用)数据结构实现HashMap结构。HashMap底层就是一个数组结构,数组中的每一项又是一个链表。

2.可以使用TreeMap,他会实现排序,可以保证键的唯一性。

Collections的工具类:此类仅由静态方法或返回集合,是针对集合操作的工具类

方法:

1.public static <T extends Comparable<? super T> void sort(List<T> list)>:将指定的列表按升序排序。

2.public static void reverse (List <?> list):反转指定列表中元素的顺序 。

3.public static void shuffle(List <?> list):使用默认的随机源随机排列指定的列表。

Collection与Collections的区别:

Collection:是一个集合接口。

Collections:是一个包装类,里面的方法都是静态的。

泛型:简单来说就类似于集合ArrayList<Sting>中的<String>就是泛型,它的本质是参数化类型(自定义对象),也就是说操作的数据类型被指定为一个参数,一提到参数,最熟悉的就是定义方法时有形参,然后调用此方法时传递参数,而参数化类型就是将类型由原来的具体的类型参数化,然后在使用/调用时传入具体的类型,这种参数类型可以用在类,方法和接口中,分别被称为泛型类,泛型方法,泛型接口。

注意:泛型的<>内其实是Object,而我们给的是要对象类型,而基本数据类型不是对象类型,所以我们知道泛型类中要用引用类型,而想要使用基本数据类型就必须转换为其包装类也就是Integer等包装类

好处:

1.把运行时期的问题提前到了编译期间。

2.避免了强制转换。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值