2014-03-07 12:18
网友采纳
Set接口也是Collection的一种扩展,而与List不同的时,在Set中的对象元素不能重复,也就是说你不能把同样的东西两次放入同一个Set容器中。它的常用具体实现有HashSet和TreeSet类。HashSet能快速定位一个元素,但是你放到HashSet中的对象需要实现hashCode()方法,它使用了前面说过的哈希码的算法。而TreeSet则将放入其中的元素按序存放,这就要求你放入其中的对象是可排序的,这就用到了集合框架提供的另外两个实用类Comparable和Comparator。一个类是可排序的,它就应该实现Comparable接口。有时多个类具有相同的排序算法,那就不需要在每分别重复定义相同的排序算法,只要实现Comparator接口即可。集合框架中还有两个很实用的公用类:Collections和Arrays。Collections提供了对一个Collection容器进行诸如排序、复制、查找和填充等一些非常有用的方法,Arrays则是对一个数组进行类似的操作。 PS: 主要优点,还是保存元素不同重复!!!
追问
我知道set下面子类如hashcode的作用,我只是想知道既然Set继承Collection 却没有声明自己的方法,这样Set借口存在存在毫无意义啊~~~
评论
|
1
0
擅长: JAVA相关 JavaScript 数据库DB
按默认排序 | 按时间排序
其他2条回答
2014-03-07 15:00
Dayday_lx
| 六级
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
Collection Set List皆为接口。
Set和List又继承了Collection接口,所以拥有Collection定义的方法
接口是不可以实例化的。
错误的方式:
Collection c =
new
Collection ();
Set s =
new
Set();
List l =
new
List();
正确的方式:
Set s1 =
new
HashSet();
Set s2 =
new
TreeSet();
因为TreeSet,HashSet实现了Set接口
List l1 =
new
ArrayList();
List l2 =
new
LinkedList();
同样ArrayList,LinkedList这
2
个又实现了List
接口不能直接被实例化,Set,list继承了Collection,
HashSet,TreeSet,ArrayList,LinkedList分别实现了Set,list接口
所以要实例化Collection 可以写成
Collection c1=
new
HashSet();
Collection c2=
new
TreeSet();
Collection c3=
new
ArrayList();
Collection c4=
new
LinkedList();
假如我定义 Collection col1=
new
LinkedList();
和 Set ss1 =
new
HashSet();做比较
col这个集合里面的元素就可以重复,
ss这个集合里面的元素不可重复
再假如我定义 Collection col2=
new
HashSet();
和 Set ss2 =
new
HashSet();做比较
col2这个集合里面的元素不可重复,
ss2 这个集合里面的元素不可重复
个人理解 ,仅供参考!!!!!!!!!!!!!!!!!!!
|
追问
我知道set下面子类如hashcode的作用,我只是想知道既然Set继承Collection 却没有声明自己的方法,这样Set借口存在存在毫无意义啊~~~ 你们似乎都没理解我的意思~~ - - !
回答
1
2
3
4
5
6
7
8
9
10
11
|
法克。区别都给你举例出来了。你问我为啥要存在?
set接口和Collection接口我已经给你列出区别了吧。
然后你又问他们两个都一样,都存在是搞毛的?
然后我想问问大神你:
你有明白继承是搞啥的么?
继承能搞啥么?
啥叫继承?
为啥要继承?
难道A里面的方法,和B继承A里面的方法 意义是一样的?晕
|