一.Iterator
1.Iterator可以对集合Set中的元素进行遍历
2.hasNext()方法用于检查集合中是否还有下一个元素
3.next()方法返回集合中的下一个元素
二.ArrayList和LinkList
1.一个LinkedList和ArrayList都实现了List接口
2.ArrayList是可以更改大小的数组,而LinkedList是链表实现的
3.LinkedList不支持高效的随机元素访问
三.final关键字
如果修饰方法,则该方法不能在子类中被覆盖
四.String、StringBuffer、StringBuilder
1.StringBuilder运行速度最快
2.StringBuffer是线程安全的
3.String值是不可变的
4.StringBuffer运行速度比String快
*String类型是字符串常量,当进行字符串操作时,地址发生改变
*StringBuffer和StringBuilder类型是字符串变量,当使用append()等操作时,内存地址不发生改变
*StringBuilder是线程不安全的,StringBuffer是线程安全的
*String使用“+”作为数据的连接操作,而StringBuilder/StringBuffer使用append()方法进行数据连接
五.java抽象类和接口的区别
1.抽象类可以有构造方法,接口不能有构造方法
2.抽象类中可以包含非抽象类的普通方法,接口中的方法必须是抽象的,不能有非抽象的普通类方法
3.一个类可以实现多个接口,只能继承一个抽象类
六.List<Object>、List<?>的区别以及<?extends T>与<?super T>的区别
1.list<?>在没有赋值以前,可以接受任何类型的集合赋值。允许删除,不允许添加
2.list<?extends T>可以赋值给任意T及T的子类集合,上界为T,取出来的类型带有泛型限制
3.list<?super T>可以赋值给任意T及T的父类集合,下界为T,取出来的类型带有泛型限制
4.list<object>只能接受object类泛型的赋值,接受其他泛型赋值时会出现编译错误
七.ArrayList和数组区别
1.初始化不同
2.存储类型不同
3.内容不同
八.Set和List的区别
1.Set接口实例存储的是无序的,不重复的数据。List接口实例存储的是有序的,可以重复的元素。都可以存储null值,但Set不能重复所以最多只能有一个空元素
2.Set检索效率低下,删除和插入效率高,插入和删除不会引起元素位置改变(实现类有HashSet、TreeSet)
3.List和数组类似,可以动态增长,根据实际存储的数据长度自动增加List的长度。查找元素效率高,插入删除效率低,因为会引起其他元素位置改变(实现ArrayList、LinkedList、Vector)
4.Set是一种不包含重复元素的Collection
5.List是有序的Collection,使用此接口能够精确地控制每个元素插入的位置
6.Map提供key到value的映射。一个Map中不能包含相同的key,每个key只能映射一个value
7.List继承自Collection接口,Set继承自Collection接口,Map与List、Set接口不同,它是由一系列键值对组成的集合。