A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

本人并不是很明白 有谁知道?

4 个回复

倒序浏览
首先,List与Set具有相似性,它们都是单列元素的集合,所以,它们有一个功共同的父接口,叫Collection。Set里面不允许有重复的元素,所谓重复,即不能有两个相等(注意,不是仅仅是相同)的对象 ,即假设Set集合中有了一个A对象,现在我要向Set集合再存入一个B对象,但B对象与A对象equals相等,则B对象存储不进去,所以,Set集合的add方法有一个boolean的返回值,当集合中没有某个元素,此时add方法可成功加入该元素时,则返回true,当集合含有与某个元素equals相等的元素时,此时add方法无法加入该元素,返回结果为false。Set取元素时,没法说取第几个,只能以Iterator接口取得所有的元素,再逐一遍历各个元素。
       List表示有先后顺序的集合, 注意,不是那种按年龄、按大小、按价格之类的排序。当我们多次调用add(Obj e)方法时,每次加入的对象就像火车站买票有排队顺序一样,按先来后到的顺序排序。有时候,也可以插队,即调用add(int index,Obj e)方法,就可以指定当前对象在集合中的存放位置。一个对象可以被反复存储进List中,每调用一次add方法,这个对象就被插入进集合中一次,其实,并不是把这个对象本身存储进了集合中,而是在集合中用一个索引变量指向这个对象,当这个对象被add多次时,即相当于集合中有多个索引指向了这个对象,如图x所示。List除了可以以Iterator接口取得所有的元素,再逐一遍历各个元素之外,还可以调用get(index i)来明确说明取第几个。
       Map与List和Set不同,它是双列的集合,其中有put方法,定义如下:put(obj key,obj value),每次存储时,要存储一对key/value,不能存储重复的key,这个重复的规则也是按equals比较相等。取则可以根据key获得相应的value,即get(Object key)返回值为key 所对应的value。另外,也可以通过keySet()获得所有的key的结合 Set<K>,还可以通过values()获得所有的value的结合Collection<V>,还可以通过entrySet()获得key和value组合成的Map.Entry对象的集合 Set<Map.Entry<K,V>>。
List 以特定次序来持有元素,可有重复元素。Set 无法拥有重复元素,内部排序。Map 保存key-value值,value可多值。
HashSet按照hashcode值的某种运算方式进行存储,而不是直接按hashCode值的大小进行存储。例如,"abc" ---> 78,"def" ---> 62,"xyz" ---> 65在hashSet中的存储顺序不是62,65,78,这些问题感谢以前一个叫崔健的学员提出,最后通过查看源代码给他解释清楚,看本次培训学员当中有多少能看懂源码。LinkedHashSet按插入的顺序存储,那被存储对象的hashcode方法还有什么作用呢?学员想想!hashset集合比较两个对象是否相等,首先看hashcode方法是否相等,然后看equals方法是否相等。new 两个Student插入到HashSet中,看HashSet的size,实现hashcode和equals方法后再看size。
同一个对象可以在Vector中加入多次。往集合里面加元素,相当于集合里用一根绳子连接到了目标对象。往HashSet中却加不了多次的

评分

参与人数 1技术分 +2 收起 理由
职业规划-刘倩老师 + 2 赞一个!

查看全部评分

回复 使用道具 举报
List,Map,set

Collection是对象集合,Collection有两个子接口List和Set
List可以通过下标(1,2..)来取得值,其值可以重复的
而Set只能通过游标来取值,并且值是不能够重复的

ArrayList,Vector,LinkedList是List的实现类
ArrayList是线程不安全的,Vector是线程安全的,这两个类的底层都是用数组来实现的
LinkedList是线程不安全的,底层是由链表实现的

Map是键值对集合
HashTable和HashMap是Map的实现类
HashTable是线程安全的,不能存储null值
HashMap不是线程安全的,可以存储null

回复 使用道具 举报
        List单列集合,表示有先后顺序的集合,按先来后到的顺序排序。有时候,也可以插队,即调用add(int index,Obj e)方法,就可以指定当前对象在集合中的存放位置。可有重复元素,可以根据索引取单个或多个值。
        Set 单列集合 里面不允许有重复的元素,无序集合,要取值只能通过循环遍历
        Map,它是双列的集合,以键值对的形式进行存取,不能存储重复的key,可以获得key和value组合成的Map.Entry对象的集合。
         List 以特定次序来持有元素,可有重复元素。Set 无法拥有重复元素,内部排序。Map 保存key-value值,value可多值。
回复 使用道具 举报
List,Map,set

Collection是对象集合,
Collection有两个子接口List和Set
List集合是有序的就是怎么进去就怎么出来可以通过下标(1,2..)来取得值,其值可以重复的而Set集合,无序,并且值是不能够重复的
ArrayList,Vector,LinkedList是List的实现类
ArrayList是线程不安全的,是数组结构,有角标。查询很快
Vector是线程安全的,有角标也是数组结构,但是查询慢增删也很慢。这两个类的底层都是用数组来实现的
LinkedList是线程不安全的,底层是由链表实现的。增删很快
Map,它是双列的集合,以键值对的形式进行存取,不能存储重复的key,可以获得key和value组合成的Map.Entry对象的集合。  Map 保存key-value值,value可多值。
HashTable是线程安全的,不能存储null值
HashMap不是线程安全的,可以存储null
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马