Java部分知识点总结(2)

一.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接口不同,它是由一系列键值对组成的集合。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值