1.集合
集合和数组既然都是容器,它们有啥区别呢?
数组的长度是固定的。集合的长度是可变的。
数组中存储的是同一类型的元素,可以存储基本数据类型值。
集合存储的都是对象。而且对象的类型可以不一致。
这些容器怎么区分?
区分的方式:每一个容器的数据结构(数据存储一种方式)不一样。
Collection根接口中定义的方法:这些方法,所有的集合类都具有
增:添加方法
-
boolean add(E e);//添加一个元素,返回值表示是否添加成功
删:删除方法
-
boolean remove(Object obj);//删除某一个元素,返回值表示是否删除成功
改:修改元素
-
无
查:获取某一个元素
-
无
- 其他:
int size();//获取长度
void clear();//删除所有元素
boolean contains(Object obj);//判断是否包含obj元素
Object[] toArray();//集合转换成数组
2.集合的遍历
在根接口中 使用了一种公共的遍历方式,迭代器遍历
1.获取一个集合的迭代器对象(迭代器对象不是我们创建的,而是每个集合自带)
2.通过循环反复调用 迭代器对象的 hasNext 和 next 方法
//1.创建一个集合对象,使用多态
Collection<String> names = new ArrayList<String>();
//2.添加
names.add("郭德纲");
names.add("刘德华");
names.add("柳岩");
names.add("范伟");
names.add("范伟1");
//3.获取names集合的迭代器对象
Iterator<String> it = names.iterator();
//4.标准代码
while(it.hasNext()){//反复判断有没有下一个元素
String s = it.next();//如果有取出下一个元素
System.out.println(s);
}
增强for循环的格式:
for(数据类型 变量名:数组/集合){
syso(变量名);
}
注意: 当你使用增强for循环遍历集合的时候,底层采用的是迭代器
总结: 当你使用增强for循环遍历集合的时候,不能修改集合的长度(Concurrent(并发)Modification(修改)Exception)
3.泛型
泛型的好处
1,将运行时期的ClassCastException,转移到了编译时期变成了编译失败。
2,避免了类型强转的麻烦。
泛型中E的含义:
是一个"变量",用来接收一种数据类型
泛型可以用在类上,方法上,接口上
1.泛型用在类上: 泛型类
格式:
public class 类名<E>
泛型类上的泛型E 到底什么时候确定?
当你创建该类的对象的时候,就可以确定
2.泛型用在方法上:泛型方法
格式:
public <T> 返回值类型 方法名(T t);
泛型方法上的T 到底什么时候确定?
当你调用方法,传递参数的时候确定
3.泛型用在接口上:泛型接口
格式:
public interface 接口名<E>
泛型接口上的泛型 到底什么时候确定?
1.实现类实现接口的时候,直接确定
2.实现类实现接口的时候,不确定泛型,而是直接把泛型继承下来
当这个实现类创建对象的时候确定
4.通配符
正则表达式中 "."代表任意字符
在DOS中 "*"代表任意内容
泛型通配符: ?:代表任意类型 <? extends Animal> : 表示一种泛型,这种泛型必须是Animal
或者Animal的子类 <? super Animal>:表示一种泛型,这种泛型必须是Animal 或者Animal的父类
在ArrayList中 有一个方法
》》》 addAll(Collection c);//把集合c里面的每一个元素添加到ArrayList中