一、LinkedList的特有功能
* A:LinkedList类特有功能
* public void addFirst(E e)及addLast(E e)
* public E getFirst()及getLast()
* public E removeFirst()及public E removeLast()
* public E get(int index);
二、栈和队列数据结构
* 栈
* 先进后出
* 队列
* 先进先出
三、泛型概述和基本使用
* A:泛型好处
* 提高安全性(将运行期的错误转换到编译期)
* 省去强转的麻烦
* B:泛型基本使用
* <>中放的必须是引用数据类型
* C:泛型使用注意事项
* 前后的泛型必须一致,或者后面的泛型可以省略不写(1.7的新特性菱形泛型)
* D:泛型的由来:通过Object转型问题引入
* 早期的Object类型可以接收任意的对象类型,但是在实际的使用中,会有类型转换的问题。也就存在这隐患,所以Java提供了泛型来解决这个安全问题。
五、泛型类
* A:泛型类概述<T>
* 把泛型定义在类上
* public class 类名<泛型类型1,…>
* 泛型类型必须是引用类型
六、泛型方法的概述和使用
* A:泛型方法概述
* 把泛型定义在方法上,方法泛型最好与类泛型一致,如果不一致,需要在方法上申明该泛型。静态方法必须申明泛型,因为随着类的加载而加载* B:定义格式
* public <泛型类型> 返回类型 方法名(泛型类型 变量名)
七、泛型接口的概述和使用
* A:泛型接口概述
* public interface 接口名<泛型类型>
八、泛型高级之通配符
* A:泛型通配符<?>
* 任意类型,如果没有明确,那么就是Object以及任意的Java类了
* B:? extends E
* 向下限定,E及其子类,比如集合,就是可以存放E及其子类
* C:? super E
* 向上限定,E及其父类
九、三种迭代的能否删除
* 普通for循环,可以删除,但是索引要--。因为是数组结构的,删除一个元素,就把后面的元素复制,向前移动一位,这样指针向下移动一位,就跳过了删除元素的下一个元素,所以如果不--的话,普通for循环的删除不能删除相邻的相同元素。
* 迭代器,可以删除,但是必须使用迭代器自身的remove方法,否则会出现并发修改异常
* 增强for循环不能删除,因为其实底层依赖的是迭代器,所以不能让集合自己删除元素,但是又获取不到迭代器对象,所以不能删除元素。
*
十、可变参数的概述和使用
* A:可变参数概述
* 定义方法的时候不知道该定义多少个参数
* B:格式
* 修饰符 返回值类型 方法名(数据类型… 变量名){}
* C:注意事项:
* 这里的变量其实是一个数组
* 如果一个方法有可变参数,并且有多个参数,那么,可变参数肯定是最后一个
十一、Arrays工具类的asList()和toArray方法的使用
* Arrays工具类的asList()方法的使用
数组转集合,虽然不能增删元素,但是可以用集合的思想操作数组,也就是说可以使用其他集合中的方法。
基本数据类型的数组转换成集合,会将整个数组当做一个对象转换,因为集合只能存储引用数组类型。想要存储,就要把数组的元素类型变成基本数据类型的包装类,这样每个元素都是对象了。
* Collection中toArray(T[] a)泛型版的集合转数组
当集合转换数组时,数组长度如果小于等于集合的size,转换后的数组长度等于集合的size,如果大于的话,数组后面的元素为null