Java之集合Collection
集合
初次学习集合过程中的学习笔记,学习顶层,使用底层.包括常用的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的更多相关文章
- java中集合Collection转list对象
参考:java中集合Collection转list对象 首先我的需求是获取到购物车列表,购物车列表是一个Map对象,构造方法获取购物项,这里购物项是Collection对象 // 购物项集合,K商品I ...
- java之集合Collection 详解之4
package cn.itcast_04; public class Student { private String name; private int age; public Student() ...
- java之集合Collection详解之3
package cn.itcast_03; public class Student { // 成员变量 private String name; private int age; // 构造方法 p ...
- java之集合Collection详解之2
package cn.itcast_02; import java.util.ArrayList; import java.util.Collection; /* * 练习:用集合存储5个学生对象,并 ...
- java之集合Collection 3个例子
package cn.itcast_01; import java.util.ArrayList; import java.util.Collection; /* * 集合的由来: * 我们学习的是面 ...
- java之集合Collection 具体解释之4
package cn.itcast_04; public class Student { private String name; private int age; public Student() ...
- java基础27 单例集合Collection及其常用方法
1.集合 集合是存储对象数据的集合容器 1.1.集合比数组的优势 1.集合可以存储任意类型的数据,数组只能存储同一种数据类型的数据 2.集合的长度是变化的,数组的长度是固定的 1.2.数组:存储 ...
- Java:集合,Collection接口框架图
Java集合大致可分为Set.List和Map三种体系,其中Set代表无序.不可重复的集合:List代表有序.重复的集合:而Map则代表具有映射关系的集合.Java 5之后,增加了Queue体系集合, ...
- Java学习:单列集合Collection
集合 学习集合的目标: 会使用集合存储数据 会遍历集合,把数据取出来 掌握每种集合的特性 集合和数组的区别 数组的长度是固定的.集合的长度是可变的. 数组中存储的是同一类型的元素,可以存储基本数据类型 ...
随机推荐
- 初学node.js-nodejs中实现HTTP服务(3)
一.node.js实现服务端 创建hello-world-server.js文件,服务端源码如下: /** * node.js实现http服务端 */ var http = require('http ...
- wifi,Android渗透之arp欺骗
查看自己wifi ip段 查看有哪些用户连接了此wifi,下图标记处为我的测试机(华为) 攻击开始,如果开启了arp防火墙,就会有提示 开启图片捕获
- 工作小应用:EXCEL查找两列重复数据
工作案例:excel存在A列.B列,需要找出B列没有A列的数据,具体做法如下(以office2007做案例): 1.点击 公式-定义名称 ,选中A列,填写名称“AAA”,选中B列,填写名称“BBB”: ...
- Python20-Day07
面向对象之继承与派生 什么是继承? 继承是一种创建新类的方式,新建的类可以继承一个或者多个父类,父类又称为基类或者超类,新建的类称为派生类或者子类 子类会‘遗传’父类的特性,从而解决代码重用问题 py ...
- 福大软工1816 · 评分结果 · Alpha冲刺
作业地址:alpha冲刺1.alpha冲刺2.alpha冲刺3.alpha冲刺4.alpha冲刺5.alpha冲刺6.alpha冲刺7.alpha冲刺8.alpha冲刺9.alpha冲刺10 作业提交 ...
- HDU 4123 Bob’s Race 树形dp+单调队列
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4123 Time Limit: 5000/2000 MS (Java/Others) Memory L ...
- TCP系列52—拥塞控制—15、前向重传与RACK重传拥塞控制处理对比
一.概述 这里主要简单分析一个丢包重传并恢复的场景,通过不同的设置让这个相同的场景分别触发RACK重传和前向重传,通过对比说明以下问题: Forward Retransmit可以产生只有重传标记的数据 ...
- quartz任务管理
导入quartz相关jar包后,要执行任务的类须实现Job接口 package quartz; import org.quartz.Job; import org.quartz.JobExecutio ...
- <mvc:annotation-driven/>的作用
<mvc:annotation-driven>的作用是: 会自动注册DefaultAnnotationHandlerMapping与AnnotationMethodHandlerAdapt ...
- VR论文调研
IEEE VR 2018 1.Avatars and Virtual Humans--人物和虚拟人物 2.Augmented Reality--增强现实 3.Body and Mind--人体和思想( ...