目录
一.集合框架:
根接口:Collection
* 子接口:List,Set......
* 实现类:
* List--> ArrayList(动态扩容的数组,线程不安全),LinkedList(链表),Vector(动态扩容的数组,线程安全)
* Set --> HashSet(哈希表),LinkedHashSet(加链表的有序哈希表),TreeSet(红黑树的有序集合)Collection接口中的公共方法
* 增: add(E e);
* 删: remove(Object obj);
* 改: 无
* 查: 无
* 其他:
* int size();//长度
* boolean contains(Object obj);
* void clear();//清空
* Object[] toArray(); //转化为数组Collection中是没有下标的
* 因为 List有下标 Set没有下标,Collection抽取是共性
在Collection中定义一种公共的遍历方式:迭代器遍历
* Iterator<和集合的一样> it = 集合对象.iterator();ps:数组结构可以使用下标来进行遍历。Set和链表都需要迭代器进行遍历。
* ListIterator是Iterator的子接口,引入了add方法,允许在集合的中间加入元素;
ps:add方法依赖于迭代器的位置。不光引入了add还加入了反向遍历的功能。
迭代器对象 有三个方法:
* hasNext();//判断有没有下一个
* next();//取出下一个
* remove();//删除上一个next返回的元素,依赖于迭代器的状态
二.增强for循环
语法比普通for循环更加简单
* 格式:
* for(数据类型 变量名:数组/集合){
*
* }
* 使用增强for循环 遍历集合的时候,底层使用了就是迭代器遍历无论使用 增强for循环 或者迭代器遍历集合
* 不能修改集合的长度,否则就是出现ConcurrentModificationException异常ps:只要长度进行了改变,就直接会报错。
三.泛型
泛型:不确定的类型。
本质:是一个"变量",用来接收一种数据类型。
泛型可以用在类上,方法上,接口上
* 1.泛型类的泛型什么时候确定? 创建类对象的时候确定
* 2.泛型方法的泛型什么时候确定? 调用该方法并传递参数的时候确定
* 3.泛型接口的泛型什么时候确定? 3.1 实现类实现接口的时候直接确定 3.2实现类也不确定,当实现类创建对象的时候确定泛型通配符:
* ?:泛型通配符
* <? extends 类名>: 代表泛型必须是该类的子类或者该类本身
* <? super 类名> : 代表泛型必须是该类的父类或者泛型本身