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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

ListMapSet三个接口,存取元素时,各有什么特点?

6 个回复

正序浏览
明白了 谢谢
回复 使用道具 举报
好东西,要跟大家分享一下的啊
回复 使用道具 举报
多谢分享
回复 使用道具 举报
顶一下。、、、、、、、
回复 使用道具 举报

这是我做过的题,很详细了  .楼主可以看看
1、 Collection和Collections有什么关系?List和Set有什么异同点?Map有哪些常用类,各有什么特点?
                 *
                 *  (1) Collection和Collections有什么关系?
                 * 答:Collection是集合体系的根接口。
                 *    Collections是操作集合框架体系的工具类,其中定义的都是静态的方法。
                 *    两者的关系因该是靠Collections提供的方法更加方便的去操作Collection集合框架体系的元素。
                 *
                 *(2)List和Set有什么异同点?
                 * 相同点:1.两者都是继承于Collection接口。
                 *      2.两者都是存储对象元素的集合。
                 *      3.两者都可以使用迭代器的方法进行集合遍历。
                 * 不同点:
                 * 1.List集合体系中的元素排序是有序的。 Set集合体系中的元素是无序的。
                 * 2.List集合中的元素是可以重复的。 Set集合中的元素是不可以重复的。
                 * 3.List集合的子类是ArrayList、LinkedList、Vector 三个子类。
                 *   Set集合的子类是HashSet、TreeSet两个子类。
                 * 4.两者对数据存储的方式不同。
                 *
                 * (3)Map有哪些常用类,各有什么特点?
                 * Map集合下有HashMap、HashTable、TreeMap三个子接口。
                 * HashTable:底层数据结构是哈希表,不可以存入空健和空值。线程同步。
                 * HashMap底层的数据结构也是哈希表。可以存入空健空值。线程非同步。
                 * TreeMap底层的数据结构是二叉树。线程非同步,也可以用于给Map集合中的健进行排序。
                 */

评分

参与人数 1技术分 +1 收起 理由
SyouRai_Tsk + 1

查看全部评分

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

不懂,欢迎继续回复!
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马