转自:http://j2eemylove.iteye.com/blog/1195823
List,Set,Map是否继承自Collection接口?
答:List,Set是,Map不是。
如图:
Collection
├List
│├LinkedList
│├ArrayList
│└Vector
│ └Stack
└Set
Map
├Hashtable
├HashMap
└WeakHashMap
Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素。一些Collection允许相同的元素而另一些不行。一些能排序而另一些不行。Java JDK不能提供直接继承自Collection的类,Java JDK提供的类都是继承自Collection的"子接口",如:List和Set。
注意:Map没有继承Collection接口,Map提供key到value的映射。一个Map中不能包含相同key,每个key只能映射一个value。Map接口提供3种集合的视图,Map的内容可以被当做一组key集合,一组value集合,或者一组key-value映射。
详细介绍:
List特点:元素有放入顺序,元素可重复
Map特点:元素按键值对存储,无放入顺序
Set特点:元素无放入顺序,元素不可重复(注意:元素虽然无放入顺序,但是元素在set中的位置是有该元素的HashCode决定的,其位置其实是固定的)
List接口有三个实现类:LinkedList,ArrayList,Vector
LinkedList:底层基于链表实现,链表内存是散乱的,每一个元素存储本身内存地址的同时还存储下一个元素的地址。链表增删快,查找慢
ArrayList和Vector的区别:ArrayList是非线程安全的,效率高;Vector是基于线程安全的,效率低
Set接口有两个实现类:HashSet(底层由HashMap实现),LinkedHashSet
SortedSet接口有一个实现类:TreeSet(底层由平衡二叉树实现)
Query接口有一个实现类:LinkList
Map接口有三个实现类:HashMap,HashTable,LinkeHashMap
HashMap非线程安全,高效,支持null;HashTable线程安全,低效,不支持null
SortedMap有一个实现类:TreeMap
其实最主要的是,list是用来处理序列的,而set是用来处理集的。Map是知道的,存储的是键值对
set 一般无序不重复.map kv 结构 list 有序
就个人而言.list 用的比较多. 其次map 最后set 至于什么情况下使用什么集合.看情况了. 也不好说.也没那么绝对.
看了下面的这个就更容易明白了
写一段代码,遍历一个List中的元素
List、Map、Set三个接口,存取元素时,各有什么特点?
- importjava.util.*;
- publicclassTest
- {
- publicstaticvoidmain(String[]arge)
- {
- Listlist=newArrayList();
- list.add(0,"a");
- list.add(1,"b");
- list.add(2,"c");
- list.add(3,"d");
- while(Iteratorit=list.iterator();it.hasNext())
- {
- Objectelement=it.next();
- System.out.println(element);
- }
- }
- }
- List、Map、Set
- List通过下标来存取和值来存取
- Map键值对应来存取
- set存取元素是无序的
- --------------------------------------------------------------------
- packagecom.operation;
- importjava.util.ArrayList;
- importjava.util.HashSet;
- importjava.util.Iterator;
- importjava.util.List;
- importjava.util.Set;
- importjava.util.TreeSet;
- publicclassUser{
- privateIntegeruserId;
- privateStringuserName;
- privateStringaddress;
- publicUser(intuserId,StringuserName,Stringaddress){
- this.userId=userId;
- this.userName=userName;
- this.address=address;
- }
- publicStringgetAddress(){
- returnaddress;
- }
- publicvoidsetAddress(Stringaddress){
- this.address=address;
- }
- publicIntegergetUserId(){
- returnuserId;
- }
- publicvoidsetUserId(IntegeruserId){
- this.userId=userId;
- }
- publicStringgetUserName(){
- returnuserName;
- }
- publicvoidsetUserName(StringuserName){
- this.userName=userName;
- }
- publicstaticvoidmain(String[]args){
- //Map<Integer,User>map=newTreeMap<Integer,User>();
- //map.put(1,newUser(1,"李伟","beijing"));
- //map.put(2,newUser(2,"王文军","beijing"));
- //
- //map.put(4,newUser(2,"abc","beijing"));
- //map.put(5,newUser(2,"abc","beijing"));
- //
- //
- //
- //Set<Integer>keys=map.keySet();
- //
- ////Iterator<Integer>it=keys.iterator();
- ////while(it.hasNext()){
- ////Integerkey=it.next();
- ////Useruser=map.get(key);
- ////System.out.println("key="+key+"\t"+"value="+user.getUserName());
- ////}
- //
- //for(Integerkey:keys){
- //Useruser1=map.get(key);
- //System.out.println("key="+key+"\t"+"value="+user1.getUserName());
- //}
- Set<String>set=newHashSet<String>();
- set.add("a");
- set.add("b");
- set.add("c");
- set.add("d");
- set.add("d");
- set.add("d");
- set.add("d");
- set.add("uuu");
- set.add("e");
- Iterator<String>it=set.iterator();
- while(it.hasNext()){
- System.out.println(it.next());
- }
- }
- }
相关推荐
// java中对象容器主要有Set,List和Map三个接口类。 // 迭代器(Iterator)模式,又叫做游标(Cursor)模式。 // GOF给出的定义为:提供一种方法访问一个容器(container)对象中的各个元素, // 而又不需暴露该...
详细介绍了java中的list、map、set的存储方式及使用方法,涵盖了多个java大侠的见解,让读者充分了解list、map、set的区别和使用
Collection,List,Set和_Map用法和区别
Set对每个对象只接受一次,并使用自己内部的排序方法(通常,你只关心某个元素是否属于Set,而不关心它的顺序–否则应该使用List)。Map同样对每个元素保存一份,但这是基于”键”的,Map也有内置的排序,因而不关心...
主要介绍了Java中的Set、List、Map的用法与区别,需要的朋友可以参考下
虽然您总要创建接口特定的实现,但访问实际集合的方法应该限制在接口方法的使用上;因此,允许您更改基本的数据结构而不必改变其它代码。 · Collection 接口是一组允许重复的对象。 · Set 接口继承 Collection,...
187、JAVA SERVLET API中forward() 与redirect()的区别? 44 189、Can a Java Thread be started from Servlet class, and what will be the implications? 45 190、What is ...
java集合类Collection、List、Set、Map的用法详解,很好的资源!
java中各种集合的用法 Java集合Collection、List、Set、Map使用详解
这种差别的原因与 Set 和 Map 在 Java 库中使用的方法有关。Map 的典型应用是访问按关键字存储的值。它支持一系列集合操作的全部,但操作的是键-值对,而不是单个独立的元素。因此 Map 需要支持 get() 和 put() 的...
主要介绍了Java集合定义与用法,结合实例形式总结分析了Java集合中Set、List和Map相关概念、功能、用法及操作注意事项,需要的朋友可以参考下
集合框架:熟悉Java集合框架中的List、Set、Map等接口及其实现类,如ArrayList、HashSet、HashMap等。 泛型:理解泛型的概念及其在Java中的应用,如泛型类和泛型方法。 并发编程:了解Java中的线程、同步、锁等机制...
JAVA集合类用法总结 概括了 java 的所有集合的用法 MAP SET List 等
Java中的集合类是用于处理数据的集合的框架,包括List、Set和Map等。 Java中的文件处理可以使用File类和IO流进行读写操作。 Java中的网络编程可以使用Socket和ServerSocket实现基于网络的应用程序开发。
掌握集合的概念、体系结构、分类及使用场景 2)了解Set接口及主要实现类(HashSet...1、集合中的List、Set、Map有哪些不同? 2、为什么使用集合框架,而尽可能少用数组作为存储结构? 3、如何使用TreeSet实现第一题?
17.SetAndList.java set的简单操作极其hashcode应用 18.Singleton.java java设计模式之单例模式 19.Factory.java 设计模式之工厂模式 20.Swing.java 介绍了java的图形应用 --课程包括了java SE的大部分常用类...
4. List、Set、Map的区别 5. 什么情况下使用List、Map、Set? 6. ArrayList和LinckedList 7. LinckedList底层 8. ArrayList底层 9. mybatis的SqlSession如何保证线程安全 10. Io有哪些流,字节流和字符流的...
3.1 如何遍历一个List/Set(foreach、Iterator、Lambda表达式) 11 3.2 如何遍历一个Map(foreach、Iterator、Lambda表达式) 11 3.3 如何实现一个Set<Student> set = new TreeSet(); 12 3.4 如何实现一个Map<...
21、List,Set,Map的区别 26、ArrayMap和HashMap的对比 29、HashMap和HashTable的区别 30、HashMap与HashSet的区别 31-40题 31、HashSet与HashMap怎么判断集合元素重复? 33、ArrayList和LinkedList的区别,...
在Java集合框架方面,文章介绍了List、Set和Map的区别和特点,以及它们的使用场景。接下来,文章重点讲解了ConcurrentHashMap的原理和实现方式,以及ThreadLocal的原理和使用场景。 最后,文章简要概述了Spring框架...