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
集合 学习集合的目标: 会使用集合存储数据 会遍历集合,把数据取出来 掌握每种集合的特性 集合和数组的区别 数组的长度是固定的.集合的长度是可变的. 数组中存储的是同一类型的元素,可以存储基本数据类型 ...
随机推荐
- Ubuntu解压zip包中文乱码
解决方法:通过unar 工具解压 步骤一: 安装unar: sudo apt-get install unrar 步骤二: 解压(以test.zip为例):unar test.zip 解压成功,乱码问 ...
- gcc 与 g++的区分较
一:gcc与g++比较 误区一:gcc只能编译c代码,g++只能编译c++代码两者都可以,但是请注意:1.后缀为.c的,gcc把它当作是C程序,而g++当作是c++程序:后缀为.cpp的,两者都会认为 ...
- Workbook对象的方法总结(二)
(1).Worksheet 对象有 row_dimensions 和 column_dimensions 属性,控制行高和列宽. 例如: >>> sheet.row_dimensio ...
- 用 requests 模块从 Web 下载文件
用 requests 模块从 Web 下载文件 requests 模块让你很容易从 Web 下载文件,不必担心一些复杂的问题,诸如网络错误.连接问题和数据压缩.requests 模块不是 Python ...
- CUDA、CUDNN在Mac Book Pro上安装的问题
由于原版MacOS自带Nvidia驱动版本过低,导致最新版本CUDA安装后无法运行.具体症状为:在编译时一切正常,在运行CUDA相关程序时报错: CUDA driver version is insu ...
- mysql/mybatis之合并两个表的查询结果
下面这段sql是把两个表中各自符合条件的count值相加,返回结果是两个之和 SELECT sum(result) FROM ( SELECT COUNT(*) result FROM TEST_A ...
- OO最后一次总结
测试与正确性论证 Dijkstra说过:“程序测试只能证明程序有错,不能证明程序正确.”所谓程序测试,实际上是测试者特意挑出一批检查数据,通过运行程序,检查每个输入数据所对应的运行结果是否符合预期要求 ...
- java的(PO,VO,TO,BO,DAO,POJO)类名包名解释
VO:值对象.视图对象 PO:持久对象 QO:查询对象 DAO:数据访问对象——同时还有DAO模式 DTO:数据传输对象——同时还有DTO模式 PO:全称是persistant object持久对象最 ...
- beta冲刺(5/7)
目录 组员情况 组员1(组长):胡绪佩 组员2:胡青元 组员3:庄卉 组员4:家灿 组员5:恺琳 组员6:翟丹丹 组员7:何家伟 组员情况 组员1(组长):胡绪佩 组员2:胡青元 组员3:庄卉 组员4 ...
- struts2.3.16.1+hibernate4.3.4+spring4.0.2
把之前的老项目用新的改了 发现新的有点很方便啊 Struts2+Hibernate+Spring整合 用的是 struts2.3.16.1 hibernate4.3.4 ...