虚线是接口,实线是实现类:

集合能够解决的问题:集合可以丽杰为是一种更高级的数组,可以保存多条数据

本质: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,必须使用方法三。否则使用方法一(键值都要)。

最新文章

  1. Ubuntu14.04下安装docker
  2. SQL Server 事件通知(Event notifications)
  3. gnuplot conditional plotting: plot col A:col B if col C == x
  4. HDU 5128 The E-pang Palace(2014广州赛区现场赛B题 计算几何)
  5. 【原】iOS学习之XMPP环境搭建
  6. js isnull 赋值方法
  7. Vim tips
  8. poj 2923 状压dp+01背包
  9. C# ref和out的区别
  10. CentOS配置SSH单向无密码访问
  11. jquery 底部导航透明度变化
  12. Android学习之listview的下拉刷新、上拉载入
  13. 共同发展一个以上的开发者账户多台电脑 证书 p12 型材 进出口
  14. Santa Claus and a Palindrome
  15. mybatis的mapper接口代理使用的三个规范
  16. tcp关闭状态详解
  17. hd loadBalanceServer F5 BIG-IP / Citrix NetScaler / Radware / Array / HAProxy /
  18. C# yield return; yield break;
  19. ajax跨域,这应该是最全的解决方案了
  20. PL/SQL学习笔记之函数

热门文章

  1. JavaScript中的typeof
  2. dedecms织梦上下页标签和CSS
  3. 47.Odoo产品分析 (五) – 定制板块(2) – 为业务自定义odoo(2)
  4. MySQL 基础知识梳理学习(六)----锁
  5. 抽象,接口和Object类
  6. Swift 访问控制
  7. samba介绍和安装
  8. C# 中利用 CRC32 值判断文件是否重复
  9. JProfiler的详细使用介绍
  10. 这可能是最简单的Page Object库