java的集合:List、Set和Map
虚线是接口,实线是实现类:
集合能够解决的问题:集合可以丽杰为是一种更高级的数组,可以保存多条数据
本质:java官方开发人员基于java的一些基础内容(数组等等)创建了一些接口和类,然后使用这些接口和类的对象来更加灵活的保存或处理多条数据。
Object是一个比较特殊的类型,在Java中有这样的一条设定,Object类是任何类的父类;
List:有序集合,类似与数组,也是给里面的元素进行了默认的排序,根据时间先后顺序排序的
用add方法向list里面添加元素,可以添加不同种类的元素
import java.util.ArrayList;
import java.util.List; public class App {
public static void main(String[] args){
/**
* 保存几个学习成绩,99,98,88,89
*/
//因为list是一个接口,所以右半边不可以写new List();必须写他的实现类
List list = new ArrayList(); //底层是一个数组 LinkedList底层是一个链表
list.add(99);
list.add(89);
list.add(88);
list.add(98);
System.out.println(list);
for(int i=0;i<list.size();i++){
System.out.println(list.get(i));
}
}
}
List和数组的区别:
1.集合中的数据类型是没有必然的要求的
2.这个list几个没有长度限制
ArrayList和LinkedList的区别:
List的泛形:指定某种类型,list 中只能存放指定的类型,比如下面的一个例子:存放一个Video类型的
package jihe; public class Video {
private String name;
private String type; public Video(String name, String type) {
this.name = name;
this.type = type;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getType() {
return type;
} public void setType(String type) {
this.type = type;
}
}
package jihe; import java.util.ArrayList;
import java.util.List; public class App {
public static void main(String[] args){ Video video1 = new Video("我不是药神","剧情");
Video video2 = new Video("风雨咒","动画");
Video video3 = new Video("延禧攻略","电视剧"); List<Video> list = new ArrayList<Video>();
list.add(video1);
list.add(video2);
list.add(video3); for(Video video:list){
System.out.println("名字是:"+video.getName()+",类型是:"+video.getType());
}
}
}
结果:
Set集合:无序集合,在放入元素时会有特点的算法为元素进行排序,但是这个算法我们猜测不到,跟先后顺序也无关。因此没有跟List一样的下标去表示里面元素,元素不可重复
package jihe; import java.util.HashSet;
import java.util.Set; public class App {
public static void main(String[] args){ Video video1 = new Video("我不是药神","剧情");
Video video2 = new Video("风雨咒","动画");
Video video3 = new Video("延禧攻略","电视剧"); Set<Video> set = new HashSet<Video>();
set.add(video1);
set.add(video2);
set.add(video3); //循环只能用增强循环,因为无序,没有下标 for(Video video:set){
System.out.println("名字是:"+video.getName()+",类型是:"+video.getType());
}
}
}
结果:和上面的list不一样是无序的
Map集合:功能比较强大,Map是放入键(key)值(value)对的形式放入。
package jihe; import java.util.*; public class App {
public static void main(String[] args){ Video video1 = new Video("我不是药神","剧情");
Video video2 = new Video("风雨咒","动画");
Video video3 = new Video("延禧攻略","电视剧"); Map<String,Video> map = new HashMap<>();
map.put("我不是药神",video1);
map.put("风雨咒",video2);
map.put("延禧攻略",video3); for(String key : map.keySet()){
System.out.println("名字是:"+map.get(key).getName()+",类型是:"+map.get(key).getType());
}
}
}
Map的遍历4种方式:
package jihe; import java.util.HashMap;
import java.util.Iterator;
import java.util.Map; public class Test { /**
* 方式一 这是最常见的并且在大多数情况下也是最可取的遍历方式。在键值都需要时使用。
*/
public void test(){ Map<Integer, Integer> map = new HashMap<>(); for (Map.Entry<Integer, Integer> entry : map.entrySet()) {
System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue());
}
} /**
* 方法二 在for-each循环中遍历keys或values,
* 如果只需要map中的键或者值,你可以通过keySet或values来实现遍历,而不是用entrySet。
* 该方法比entrySet遍历在性能上稍好(快了10%),而且代码更加干净。
*/
public void test1(){
Map<Integer, Integer> map = new HashMap<>();
//遍历map中的键
for (Integer key : map.keySet()) {
System.out.println("Key = " + key);
}
//遍历map中的值
for (Integer value : map.values()) {
System.out.println("Value = " + value);
}
} /**
* 方法三使用Iterator遍历,使用泛型:
*/
public void test2(){
Map<Integer, Integer> map = new HashMap<>();
Iterator<Map.Entry<Integer, Integer>> entries = map.entrySet().iterator();
while (entries.hasNext()) {
Map.Entry<Integer, Integer> entry = entries.next();
System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue());
}
} /**
* 方法三使用Iterator遍历 ,不使用泛型
* 你也可以在keySet和values上应用同样的方法。
*
* 该种方式看起来冗余却有其优点所在。首先,在老版本java中这是惟一遍历map的方式。另一个好处是,你可以在遍历时调用iterator.remove()来删除entries,另两个方法则不能。根据javadoc的说明,如果在for-each遍历中尝试使用此方法,结果是不可预测的。
*
* 从性能方面看,该方法类同于for-each遍历(即方法二)的性能。
*/
public void test3(){ Map map = new HashMap();
Iterator entries = map.entrySet().iterator();
while (entries.hasNext()) {
Map.Entry entry = (Map.Entry) entries.next();
Integer key = (Integer)entry.getKey();
Integer value = (Integer)entry.getValue();
System.out.println("Key = " + key + ", Value = " + value);
}
} /**
* 方法四、通过键找值遍历(效率低)
*/
public void test4() {
Map<Integer, Integer> map = new HashMap<Integer, Integer>();
for (Integer key : map.keySet()) {
Integer value = map.get(key);
System.out.println("Key = " + key + ", Value = " + value);
}
} }
总结
如果仅需要键(keys)或值(values)使用方法二。如果你使用的语言版本低于java 5,或是打算在遍历时删除entries,必须使用方法三。否则使用方法一(键值都要)。
java的集合:List、Set和Map的更多相关文章
- java的集合框架set 和map的深入理解
Java的集合框架之Map的用法详解 Map有两种比较常用的实现:HashMap 和 TreeMap. HashMap: HashMap 也是无序的,也是按照哈希编码来排序的,允许使用null 值和n ...
- 【Java】集合概述Collection、Map
Java集合分为Collection和Map,Collection又分为List.Set. List中有ArrayList.LinkedList和Vector:Set中又分为HashSet和TreeS ...
- java学习——集合框架(泛型,Map)
泛型: ... Map:一次添加一对元素.Collection 一次添加一个元素. Map也称为双列集合,Collection集合称为单列集合. 其实map集合中存储的就是键值对. map集合中必须保 ...
- 【Java】集合遍历--List和Map的多种遍历方式
1. List的两种遍历方式 package com.nova.test; import java.util.ArrayList; import java.util.Iterator; import ...
- 【Java】集合_学习笔记
一.集合 1.集合类也称容器类,主要负责保存.盛装其他数据. 2.集合可以保存数量不确定的数据,保存具有映射关系的数据(也称关联数组). 3.Java5后提供一些多线程安全的集合类,放在java.ut ...
- Java 集合系列14之 Map总结(HashMap, Hashtable, TreeMap, WeakHashMap等使用场景)
概要 学完了Map的全部内容,我们再回头开开Map的框架图. 本章内容包括:第1部分 Map概括第2部分 HashMap和Hashtable异同第3部分 HashMap和WeakHashMap异同 转 ...
- Java基础(40):Java中的集合介绍---Collection与Map
集合类说明及区别Collection├List│├LinkedList│├ArrayList│└Vector│ └Stack└SetMap├Hashtable├HashMap└WeakHashMap ...
- Android(java)学习笔记105:Map集合的遍历之键值对对象找键和值
package cn.itcast_01; import java.util.HashMap; import java.util.Map; import java.util.Set; /* * Map ...
- Android(java)学习笔记104:Map集合的遍历之键找值
package cn.itcast_01; import java.util.HashMap; import java.util.Map; import java.util.Set; /* * Map ...
- Android(java)学习笔记103:Map集合的获取功能
package cn.itcast_01; import java.util.Collection; import java.util.HashMap; import java.util.Map; i ...
随机推荐
- [20190419]shared latch spin count 2.txt
[20190419]shared latch spin count 2.txt --//上午测试shared latch XX模式的情况,链接:http://blog.itpub.net/267265 ...
- 记录Nginx作为静态资源web服务场景配置
server { listen 80; server_name localhost; sendfile on; access_log /var/log/nginx/host.ac ...
- 《神经网络算法与实现-基于Java语言》的读书笔记
文章提纲 全书总评 读书笔记 C1.初识神经网络 C2.神经网络是如何学习的 C3.有监督学习(运用感知机) C4.无监督学习(自组织映射) Rreferences(参考文献) 全书总评 书本印刷质量 ...
- 微信连wifi认证
官网 https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1444894086 https://blog.csdn.net/u0116 ...
- zcu102 hdmi example(一)
1,概述 有一个计划是打算做一个摄像头的驱动与显示. 但是实际上手上只有一个zcu102开发板,没有摄像头,也没有上位机,自己也不会写.所以就将方案阉割成将录制好的视频放在SD卡里面,然后从SD卡里面 ...
- 我对DFS的理解
我对DFS的理解 [何为DFS] 深度优先搜索(Depth-First-Search),简称DFS.是一种常见搜索算法.其方法是从原点不断一条路扩散,当无路可走时回退来走下一条路,直至找到目标或遍历. ...
- linux系统设置cpu孤立
介绍 针对cpu密集型的任务,消耗cpu较高,最好设置cpu亲和度,以提高任务执行效率,避免cpu进行上下文切换,浪费不必要的性能. 特定任务(进程/线程)需要独占一个cpu核心并且不想让其他任务(进 ...
- WebApi(五)-Swagger接口文档①简单集成
1,通过NuGet引用Swashbuckle 2,打开项目属性-->生成,勾选XML文档文件,保存 3,找到项目App_Start文件夹下WebApiConfig查找GetXmlComments ...
- 使用eclipse启动tomcat里的项目时报错:java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderListener
1.这种错:java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderListener刚开始看的时候 ...
- Linux学习之路3-HelloWorld
1.window系统上创建helloworld.c文件,并编写程序 #include <stdio.h> main(){ printf("Hello World!"); ...