Map,List的用法与区别,很基础,蛋或许你不通透

简介: Map,List的用法与区别,很基础,蛋或许你不通透

区别:

List:是存储单列数据的集合,存储的数据是有序并且是可以重复的  

Map:存储双列数据的集合,通过键值对存储数据,存储 的数据是无序的,Key值不能重复,value值可以重复 key和value是一一对应的

关系:

c69f0eeec1e18e44ed12cd6896165bb.png

Collection是Java中最基本的集合接口。

Set接口:

Set接口直接继承自Collection接口,并且方法接口上也一模一样。Set对添加的元素有一些要求,其不允许出现重复的元素,并且元素之间没有次序。这相当于一个不允许重复的离散的集合。因此,添加进Set的元素类型需要定义equals方法。若是使用自定义的类,则应该重写equals方法来确保实现自己需要的功能。

Set接口主要实现了两个类:HashSet,TreeSet。

HashSet是按照哈希来存取元素的,因此速度较快。HashSet继承自抽象类AbstractSet,然后实现了Set、Cloneable、Serializable接口。  

TreeSet也是继承自AbstractSet,不过不同的是其实现的是NavigableSet接口。而NavigableSet继承自SortedSet。SortedSet是一个有序的集合。其添加的元素必须实现了Comparable接口,因为其在添加一个元素的时候需要进行排序。NavigableSet则提供了更多的有关元素次序的方法。

 

LinkedHashSet也是Set的一个实现。和HashSet类似,只不过内部用链表来维护,按照元素插入次序来保存。

List接口:

List接口也是继承自Collection。与Set不同的是,List可以存储重复的元素。主要有两种实现:ArrayList和LinkedList。  

ArrayList没有什么好说的,就像传统的数组一样,有着很快的随机存取速度,但是插入删除的速度就很慢。  

LinkedList则与ArrayList恰恰相反,因为用链表来保存数据,所以插入删除元素的速度很快,但是访问数据的速度就不如ArrayList了。

Map接口:

Map(映射)是一个存储键值对的容器接口。每一个元素包含一个key对象和value对象,且元素不允许重复。  

Map接口的实现有以下几个:  

HashMap是最常用的一个实现。HashMap使用hash映射来存取数据,这个速度是相当快,是O(1)的速度。其容量capacity,和负载因子load factor可以在一开始设定。当元素个数达到capacity*load factor的时候,就会进行扩容。  

LinkedHashMap和HashMap类似,只不过内部用链表来维护次序。因此遍历时候的顺序是其插入顺序。  

TreeMap是基于红黑树的Map,插入的数据被有次序保存,并且有很高的效率。因此在遍历输出的时候可以得到排序的数据。但是这要求插入的数据实现了comparable接口。

总结:

Collection、Set、List和Map都是接口,不能被实例化。

Set和List都继承自Collection,而Map则和Collection没什么关系。

Set和List的区别在于Set不能重复,而List可以重复。

Map和Set与List的区别在于,Map是存取键值对,而另外两个则是保存一个元素。

 

用法:

(一):List

1:声明一个List

// Object:指List里的值是什么类型的,Object代表可以是任何形式的
List<Object> list = new ArrayList<Object>();

2:方法

(1):add()   添加数据

list.add("北京");
list.add("深圳");
list.add("上海");

(2):get(index)

list.get(0) // 结果:北京

(3):size()  list里的数据个数

list.size()

(4):遍历list

for(int i=0;i<list.size();i++){
    System.out.println(list.get(i));
}

list取值是通过下标,下标从0开始

(二):  Map

1:声明一个Map

// 说明:Map是通过key-value(值键对) ,String代表key的类型(一般都是String),Object代表value的类型
Map<String,Object> map = new HashMap<String,Object>();

2:put(key,value)  赋值

map.put("name", "小明");
map.put("sex", "男");
map.put("age", 18);

3:get(key)  取值

// 结果:小明
map.get("name") 

(三):List

1:声明一个List

List<Map<String,Object>> listMap = new ArrayList<Map<String,Object>>();

2:赋值

(1):先赋值给Map

Map<String,Object> map1 = new HashMap<String,Object>();
map1.put("name", "小明");
map1.put("sex", "男");
map1.put("age", 18);
Map<String,Object> map2 = new HashMap<String,Object>();
map2.put("name", "小红");
map2.put("sex", "女");
map2.put("age", 16);

(2):将map添加到List中

listMap.add(map1);
listMap.add(map2);
// 结果:[{sex=男, name=小明, age=18}, {sex=女, name=小红, age=16}]

(3):遍历存值

  List<Map<String,Object>> listMap = new ArrayList<Map<String,Object>>();
            List<LandBaseInfo> list = landBaseInfoDao.getAllProList();
            for(int i = 0;i<list.size();i++){
                // 关键点,map命名写在循环里
                Map<String,Object> map = new HashMap<String,Object>();
                String areaName = list.get(i).getAreaName();
                if(areaName == "市本级"){
                    areaName = list.get(i).getDistrict();
                }
                String landPostition = list.get(i).getLandPosition();
                String adddress = "河南省"+areaName+landPostition ;
                String landId = list.get(i).getLandId();
                String landCode = list.get(i).getLandCode();
                String type = "2";
                map.put("address",adddress);
                map.put("landId",landId);
                map.put("landCode",landCode);
                map.put("type",type);
                listMap.add(map);
 }        

(4):遍历取值

for(int i = 0;i<listMap.size();i++){
System.out.print(listMap.get(i).get("name"));
System.out.print(listMap.get(i).get("sex"));
System.out.print(listMap.get(i).get("age"));
System.out.println();
}

来源:万里哥

https://www.cnblogs.com/wanlige/p/13048366.html

目录
相关文章
|
1月前
|
算法
你对Collection中Set、List、Map理解?
你对Collection中Set、List、Map理解?
74 18
你对Collection中Set、List、Map理解?
|
1月前
|
存储 缓存 安全
只会“有序无序”?面试官嫌弃的List、Set、Map回答!
小米,一位热衷于技术分享的程序员,通过与朋友小林的对话,详细解析了Java面试中常见的List、Set、Map三者之间的区别,不仅涵盖了它们的基本特性,还深入探讨了各自的实现原理及应用场景,帮助面试者更好地准备相关问题。
65 20
|
2月前
|
存储 C++ 容器
【C++】map、set基本用法
本文介绍了C++ STL中的`map`和`set`两种关联容器。`map`用于存储键值对,每个键唯一;而`set`存储唯一元素,不包含值。两者均基于红黑树实现,支持高效的查找、插入和删除操作。文中详细列举了它们的构造方法、迭代器、容量检查、元素修改等常用接口,并简要对比了`map`与`set`的主要差异。此外,还介绍了允许重复元素的`multiset`和`multimap`。
46 3
【C++】map、set基本用法
|
3月前
|
存储 JavaScript 前端开发
Set、Map、WeakSet 和 WeakMap 的区别
在 JavaScript 中,Set 和 Map 用于存储唯一值和键值对,支持多种操作方法,如添加、删除和检查元素。WeakSet 和 WeakMap 则存储弱引用的对象,有助于防止内存泄漏,适合特定场景使用。
|
3月前
|
存储 缓存 Java
【用Java学习数据结构系列】HashMap与TreeMap的区别,以及Map与Set的关系
【用Java学习数据结构系列】HashMap与TreeMap的区别,以及Map与Set的关系
53 1
|
4月前
|
算法
你对Collection中Set、List、Map理解?
你对Collection中Set、List、Map理解?
48 5
WK
|
4月前
|
Python
map和filter的区别是什么
`map()`和`filter()`均为Python中的高阶函数,前者针对可迭代对象中的每个元素执行指定操作,如数值翻倍或字符串转大写;后者则筛选出符合条件的元素,例如仅保留偶数或非空字符串。两者均返回迭代器,并可通过`list()`等函数转换为所需的数据结构。具体使用时,应依据实际需求和场景选择合适的函数。
WK
41 1
WK
|
4月前
map和filter的区别是什么
在编程中,`map` 和 `filter` 是处理数组或集合时常用的两个函数。`map` 用于将每个元素通过指定函数转换后生成新的数组,而 `filter` 则根据条件筛选出符合条件的元素组成新数组。两者的主要区别在于:`map` 的返回数组长度与原数组相同,但元素被转换;`filter` 的返回数组长度可能不同,只包含符合条件的元素。
WK
76 2
|
4月前
数组方法中的`forEach()`方法和`map()`方法有什么区别?
数组方法中的`forEach()`方法和`map()`方法有什么区别?
|
5月前
|
存储 Java 索引