注意:
如果想让两个自定义对象在比较的时候比较的是具体的属性值,那么就要重写这个类的equals方法。
集合中的remove(Object o)这个方法底层依赖的就是equals方法
集合中的contains方法底层也是依赖equals方法
LinkedList类特有功能:
public void addFirst(E e)及addLast(E e)
public E getFirst()及getLast()
public E removeFirst()及
public E removeLast()
public E get(int index);
栈和队列数据结构特点:
栈
先进后出
队列
先进先出
练习:
需求:请用LinkedList模拟栈数据结构的集合,并测试
创建一个类将Linked中的方法封装
public class Stack {
private LinkedList list = new LinkedList(); //创建LinkedList对象
public void in(Object obj) {
list.addLast(obj); //封装addLast()方法
}
public Object out() {
return list.removeLast(); //封装removeLast()方法
}
public boolean isEmpty() {
return list.isEmpty(); //封装isEmpty()方法
}
}
泛型概述
规定某一数据类型。在集合中就是规定集合存储的数据类型。
泛型好处
提高安全性(将运行期的错误转换到编译期)
省去强转的麻烦
泛型基本使用
<>中放的必须是引用数据类型
泛型使用注意事项
前后的泛型必须一致,或者后面的泛型可以省略不写(1.7的新特性菱形泛型)
泛型的由来:通过Object转型问题引入
早期的Object类型可以接收任意的对象类型,但是在实际的使用中,会有类型转换的问题。也就存在这隐患,所以Java提供了泛型来解决这个安全问题。
泛型类概述<T>
把泛型定义在类上
定义格式
public class 类名<泛型类型1,…>
注意事项
泛型类型必须是引用类型
泛型方法概述
把泛型定义在方法上
定义格式
public <泛型类型> 返回类型 方法名(泛型类型 变量名)
案例演示
泛型方法的使用
泛型接口概述
把泛型定义在接口上
定义格式
public interface 接口名<泛型类型>
泛型通配符<?>
任意类型,如果没有明确,那么就是Object以及任意的Java类了
<? extends E>
向下限定,E及其子类
<? super E>
向上限定,E及其父类
增强for概述
简化数组和Collection集合的遍历
格式:
for(元素数据类型 变量 : 数组或者Collection集合) {
使用变量即可,该变量就是元素
}
三种迭代的能否删除
普通for循环,可以删除,但是索引要--
迭代器,可以删除,但是必须使用迭代器自身的remove方法,否则会出现并发修改异常
增强for循环不能删除
静态导入概述
格式:
import static 包名….类名.方法名;
可以直接导入到方法的级别
注意事项
方法必须是静态的,如果有多个同名的静态方法,容易不知道使用谁?这个时候要使用,必须加前缀。由此可见,意义不大,所以一般不用,但是要能看懂。
可变参数概述
定义方法的时候不知道该定义多少个参数
格式
修饰符 返回值类型 方法名(数据类型… 变量名){}
注意事项:
这里的变量其实是一个数组
如果一个方法有可变参数,并且有多个参数,那么,可变参数肯定是最后一个
数组集合转换:
Arrays工具类的asList()方法的使用
Collection中toArray(T[] a)泛型版的集合转数组
|
|