集合

初次学习集合过程中的学习笔记,学习顶层,使用底层.包括常用的API

Collection接口

概述

  • 集合 : 集合是Java中提供的一种容器,可以用来存储多个数据.
与数组的区别:
  • 数组的长度是固定的,集合的长度是可变的.
  • 数组只能存储同一种数据类型,集合可以存储任意数据类型.
  • 数组可以存储基本数据类型和引用数据类型,集合只能存储引用数据类型.

集合的继承结构

List特点 : 存储有序(存取顺序一致),有索引,可以存储重复的元素

Set特点 : 存储无序(LinkedHashSet除外),没有索引,不可以存储重复的元素

共性方法

  • public boolean add(E e) : 把给定的对象添加到当前集合中,可以添加给定对象以及给定对象的子类。
  • public void clear() :清空集合中所有的元素。
  • public boolean remove(Object o) : 把给定的对象在当前集合中删除。对象不存在,返回false.
  • public boolean contains(Object o) : 判断当前集合中是否包含给定的对象。
  • public boolean isEmpty() : 判断当前集合是否为空。
  • public int size() : 返回集合中元素的个数。
  • public Object[] toArray() : 把集合中的元素,存储到数组中。

迭代器

迭代器用来遍历集合,使用下面的方法来创建迭代器:

  • Iterator iterator() 返回此集合中元素的迭代器。

迭代器中常用方法:

  • boolean hasNext() 如果迭代具有更多元素,则返回 true 。
  • E next() 返回迭代中的下一个元素。

如何遍历集合? 如下:

 // 创建集合
ArrayList<Student> stuList = new ArrayList<>();
// 创建学生对象
Student stu1 = new Student("赵丽颖",23);
stuList.add(stu1);
stuList.add(new Student("郑爽",22));
stuList.add(new Student("杨幂",34));
stuList.add(new Student("迪丽热巴",22));
// 使用迭代器进行遍历
Iterator<Student> iterator = stuList.iterator();
while(iterator.hasNext()){
System.out.println(iterator.next());
}
System.out.println("=======================");
// 使用增强for循环的遍历
for (Student student : stuList) {
System.out.println(student);
}
System.out.println("=======================");
// 使用数组进行遍历,注意的是只能用Object数组进行接收
Object[] objs = stuList.toArray();
for (int i = 0; i < objs.length; i++) {
System.out.println(objs[i]);
}

增强for循环

增强for循环(也称for each循环)是JDK1.5以后出来的一个高级for循环,遍历集合内部原理其实是个Iterator迭代器,所以它只进行遍历元素,不要在遍历的过程中对集合元素进行增删操作。遍历数组内部原理其实是个普通for循环.

就是上面的第二种方式

新for循环必须有被遍历的目标。目标只能是Collection或者是数组。新式for仅仅作为遍历操作出现。

泛型

概念

广泛的数据类型,将数据类型的确认推迟到使用的时候.

泛型只能是引用数据类型.

泛型类的定义

在定义类的时候,在类名后加上,例如:

class A<E>{
}

泛型类在创建对象的时候确定类型.

定义含有泛型的方法

格式如下:

修饰符 <泛型> 返回值 方法名(泛型参数列表){}

例子:

public <E> void method1(E e){
System.out.println(e);
}

使用的时候创建对象,调用方法,可以传入各种数据类型.

定义泛型的接口

格式如下:

interface 接口名{}

泛型接口的子实现类有两种方式:

  • 带泛型的 : class 类名 implements 接口名{}
  • 不带泛型的 : class 类名 implements 接口名{}

也就是说实现的子接口可以确定泛型的类型,也可以不确定,继续使用泛型,这就是两种方式.

泛型通配符

当使用泛型类或者接口时,传递的数据中,泛型类型不确定,可以通过通配符<?>表示。但是一旦使用泛型的通配符后,只能使用Object类中的共性方法,集合中元素自身方法无法使用.

不知道使用什么类型来接收的时候,此时可以使用?,?表示未知通配符。

例子:

public static void main(String[] args) {
Collection<Intger> list1 = new ArrayList<Integer>();
getElement(list1);
Collection<String> list2 = new ArrayList<String>();
getElement(list2);
}
public static void getElement(Collection<?> coll){}
//?代表可以接收任意类型

高级用法:

  • 泛型的上限:

    格式: 类型名称 <? extends 类 > 对象名称

    意义: 只能接收该类型及其子类

  • 泛型的下限:

    格式: 类型名称 <? super 类 > 对象名称

    意义: 只能接收该类型及其父类型

    举个例子:

    public static void main(String[] args) {

    Collection list1 = new ArrayList();

    Collection list2 = new ArrayList();

    Collection list3 = new ArrayList();

    Collection list4 = new ArrayList();

      getElement1(list1);
    getElement1(list2);//报错
    getElement1(list3);
    getElement1(list4);//报错 getElement2(list1);//报错
    getElement2(list2);//报错
    getElement2(list3);
    getElement2(list4);

    }

    // 泛型的上限:此时的泛型?,必须是Number类型或者Number类型的子类

    // Integer extends Number extends Object

    // String extends Object

    public static void getElement1(Collection<? extends Number> coll){}

    // 泛型的下限:此时的泛型?,必须是Number类型或者Number类型的父类

    public static void getElement2(Collection<? super Number> coll){}

来个更明显的例子,四个类,如下:

public class People {

    /**
* 姓名
*/
private String name; /**
* 年龄
*/
private int age; public People(String name, int age) {
this.name = name;
this.age = age;
} public People() {
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} @Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
} public class Student extends People{ public Student(String name, int age) {
super(name, age);
} public Student() {
}
} public class BasicStudent extends Student{ public BasicStudent(String name, int age) {
super(name, age);
} public BasicStudent() {
}
} public class DemoTest2 { public static void main(String[] args) {
ArrayList<People> arrList1 = new ArrayList<>(); // boolean add(E e) 确保此集合包含指定的元素(可选操作)。
// 说明add方法可以添加指定对象以及指定对象的子类
arrList1.add(new Student("迪丽热巴",22));
arrList1.add(new BasicStudent("邓伦",23)); ArrayList<Student> arrList2 = new ArrayList<>();
ArrayList<BasicStudent> arrList3 = new ArrayList<>();
ArrayList<People> arrList4 = new ArrayList<>(); // boolean addAll(Collection<? extends E> c) 将指定集合中的所有元素添加到此集合(可选操作)。
// 测试addAll方法
arrList2.add(new Student("迪丽热巴",22));
arrList2.add(new Student("邓伦",23)); arrList3.add(new BasicStudent("杨幂",34));
arrList3.add(new BasicStudent("郑恺威",35)); arrList4.add(new People("杨洋",24));
arrList4.add(new People("郑爽",23)); // 可以添加成功
arrList2.addAll(arrList3);
// 报错,添加失败,原因是addAll方法的参数中通配符有上界的限制,只能添加该类以及该类的子类,不能添加父类等其他类
// arrList2.addAll(arrList4); System.out.println(arrList2); }
}

最后再来个小案例,案例要求如下:

按照斗地主的规则,完成洗牌发牌的动作。 具体规则:

使用54张牌打乱顺序,三个玩家参与游戏,三人交替摸牌,每人17张牌,最后三张留作底牌。

/**
* 斗地主的测试类
* 1.买牌
* 2.洗牌
* 3.发牌
* 4.看牌
*
* @author WZLOVE
* @create 2018-07-11 17:36
*/
public class DDZDemoTest { public static void main(String[] args) { // 买牌
ArrayList<String> poker = new ArrayList<>(); String[] arr1 = {"♠","♥","♣","♦"};
String[] arr2 = {"2","A","K","Q","J","10","9","8","7","6","5","4","3"};
for (String s : arr1) {
for (String s1 : arr2) {
poker.add(s + s1);
}
}
poker.add("大王");
poker.add("小王");
System.out.println(poker.size()); // 洗牌
Collections.shuffle(poker); // 发牌
ArrayList<String> people1 = new ArrayList<>();
ArrayList<String> people2 = new ArrayList<>();
ArrayList<String> people3 = new ArrayList<>();
ArrayList<String> dipai = new ArrayList<>(); // 自己的思路
/*for (int i = 0; i < poker.size();) {
if(i >= 51){
dipai.add(poker.get(i++));
} else{
people1.add(poker.get(i++));
people2.add(poker.get(i++));
people3.add(poker.get(i++));
}
}*/ // 老师的思路
for (int i = 0; i < poker.size();i++) {
if(i >= 51){
dipai.add(poker.get(i));
} else if(i % 3 == 0) {
people1.add(poker.get(i));
}else if(i % 3 == 1) {
people2.add(poker.get(i));
}else if(i % 3 == 2){
people3.add(poker.get(i));
}
}
// 看牌
System.out.println(people1);
System.out.println(people2);
System.out.println(people3);
System.out.println(dipai); }
}

Java之集合Collection的更多相关文章

  1. java中集合Collection转list对象

    参考:java中集合Collection转list对象 首先我的需求是获取到购物车列表,购物车列表是一个Map对象,构造方法获取购物项,这里购物项是Collection对象 // 购物项集合,K商品I ...

  2. java之集合Collection 详解之4

    package cn.itcast_04; public class Student { private String name; private int age; public Student() ...

  3. java之集合Collection详解之3

    package cn.itcast_03; public class Student { // 成员变量 private String name; private int age; // 构造方法 p ...

  4. java之集合Collection详解之2

    package cn.itcast_02; import java.util.ArrayList; import java.util.Collection; /* * 练习:用集合存储5个学生对象,并 ...

  5. java之集合Collection 3个例子

    package cn.itcast_01; import java.util.ArrayList; import java.util.Collection; /* * 集合的由来: * 我们学习的是面 ...

  6. java之集合Collection 具体解释之4

    package cn.itcast_04; public class Student { private String name; private int age; public Student() ...

  7. java基础27 单例集合Collection及其常用方法

    1.集合 集合是存储对象数据的集合容器 1.1.集合比数组的优势 1.集合可以存储任意类型的数据,数组只能存储同一种数据类型的数据    2.集合的长度是变化的,数组的长度是固定的 1.2.数组:存储 ...

  8. Java:集合,Collection接口框架图

    Java集合大致可分为Set.List和Map三种体系,其中Set代表无序.不可重复的集合:List代表有序.重复的集合:而Map则代表具有映射关系的集合.Java 5之后,增加了Queue体系集合, ...

  9. Java学习:单列集合Collection

    集合 学习集合的目标: 会使用集合存储数据 会遍历集合,把数据取出来 掌握每种集合的特性 集合和数组的区别 数组的长度是固定的.集合的长度是可变的. 数组中存储的是同一类型的元素,可以存储基本数据类型 ...

随机推荐

  1. 初学node.js-nodejs中实现HTTP服务(3)

    一.node.js实现服务端 创建hello-world-server.js文件,服务端源码如下: /** * node.js实现http服务端 */ var http = require('http ...

  2. wifi,Android渗透之arp欺骗

    查看自己wifi ip段 查看有哪些用户连接了此wifi,下图标记处为我的测试机(华为) 攻击开始,如果开启了arp防火墙,就会有提示 开启图片捕获

  3. 工作小应用:EXCEL查找两列重复数据

    工作案例:excel存在A列.B列,需要找出B列没有A列的数据,具体做法如下(以office2007做案例): 1.点击 公式-定义名称 ,选中A列,填写名称“AAA”,选中B列,填写名称“BBB”: ...

  4. Python20-Day07

    面向对象之继承与派生 什么是继承? 继承是一种创建新类的方式,新建的类可以继承一个或者多个父类,父类又称为基类或者超类,新建的类称为派生类或者子类 子类会‘遗传’父类的特性,从而解决代码重用问题 py ...

  5. 福大软工1816 · 评分结果 · Alpha冲刺

    作业地址:alpha冲刺1.alpha冲刺2.alpha冲刺3.alpha冲刺4.alpha冲刺5.alpha冲刺6.alpha冲刺7.alpha冲刺8.alpha冲刺9.alpha冲刺10 作业提交 ...

  6. HDU 4123 Bob’s Race 树形dp+单调队列

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4123 Time Limit: 5000/2000 MS (Java/Others) Memory L ...

  7. TCP系列52—拥塞控制—15、前向重传与RACK重传拥塞控制处理对比

    一.概述 这里主要简单分析一个丢包重传并恢复的场景,通过不同的设置让这个相同的场景分别触发RACK重传和前向重传,通过对比说明以下问题: Forward Retransmit可以产生只有重传标记的数据 ...

  8. quartz任务管理

    导入quartz相关jar包后,要执行任务的类须实现Job接口 package quartz; import org.quartz.Job; import org.quartz.JobExecutio ...

  9. <mvc:annotation-driven/>的作用

    <mvc:annotation-driven>的作用是: 会自动注册DefaultAnnotationHandlerMapping与AnnotationMethodHandlerAdapt ...

  10. VR论文调研

    IEEE VR 2018 1.Avatars and Virtual Humans--人物和虚拟人物 2.Augmented Reality--增强现实 3.Body and Mind--人体和思想( ...