对象数组
存的是一个对象
import java.util.Arrays;
public class MyTest {
public static void main(String[] args) {
//需求:我有3个学生,请把这个3个学生的信息存储到数组中,并遍历数组,获取得到每一个学生信息。
// 学生:Student
// 成员变量:name,age
// 构造方法:无参,带参
// 成员方法:getXxx()/setXxx()
Student s1 = new Student("苏沅湘", 20);
Student s2 = new Student("崔季宣", 20);
Student s3 = new Student("周颖", 18);
//把要把上面三个学生对象存储起来
//数组,字符串缓冲区
//对象数组
Student[] students={s1,s2,s3};
for (int i = 0; i < students.length; i++) {
Student student = students[i];
System.out.println(student.getName()+"==="+student.getAge());
}
//删掉数组中的第三个元素
Student[] students1 = Arrays.copyOf(students, 2);
System.out.println(Arrays.toString(students1));
}
}
public class Student {
private String name;
private int age;
public Student() {
}
public Student(String name, int age) {
this.name = name;
this.age = age;
}
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;
}
}
集合
数组作为容器:可以存储多种多样的类型,但是数组作为容器,增删数组中的元素是很不方便的。
那Java为了我们更方便的去操作(增删改查)容器中的元素,给我们提供了另外一个容器,叫做集合
数组和集合的区别
(1): 长度区别:
数组的长度是固定的而集合的长度是可变的
(2): 存储数据类型的区别:
数组可以存储基本数据类型 , 也可以存储引用数据类型; 而集合只能存储引用数据类型
(3): 内容区别:
数组只能存储同种数据类型的元素 ,集合可以存储不同类型的元素
Collection集合
Collection的功能概述
a:添加功能
boolean add(Object obj):添加一个元素
boolean addAll(Collection c):添加一个集合的元素 (给一个集合添加进另一个集合中的所有元素)
b:删除功能
void clear():移除所有元素
boolean remove(Object o):移除一个元素
boolean removeAll(Collection c):移除一个集合的元素(移除一个以上返回的就是true) 删除的元素是两个集合的交集元素
如果没有交集元素 则删除失败 返回false
c:判断功能
boolean contains(Object o):判断集合中是否包含指定的元素
boolean containsAll(Collection c):判断集合中是否包含指定的集合元素(这个集合 包含 另一个集合中所有的元素才算包含 才返回true)
比如:1,2,3 containsAll 12=true 1,2,3 containsAll 2,3,4=false
boolean isEmpty():判断集合是否为空
d:获取功能
Iterator<E> iterator()(重点)
e:长度功能
int size():元素的个数
f:交集功能
//例如:A集合对B集合取交集,获取到的交集元素在A集合中。返回的布尔值表示的是A集合是否发生变化
boolean retainAll(Collection c):获取两个集合的交集元素(交集:两个集合都有的元素)
g:把集合转换为数组
Object[] toArray()
功能的演示
import java.util.ArrayList;
import java.util.Collection;
public class MyTest {
public static void main(String[] args) {
// Collection 接口 是个单列集合的父类
//多态
Collection collection = new ArrayList();
//往集合中添加元素,返回值的意思是 是否添加成功
boolean b = collection.add("aaa");
collection.add("bbb");
collection.add("ccc");
System.out.println(collection);
}
}
import jdk.management.resource.internal.inst.SocketInputStreamRMHooks;
import java.util.ArrayList;
import java.util.Collection;
public class MyTest2 {
public static void main(String[] args) {
//addAll() 把两个集合中 的元素放到一个集合中
Collection collection = new ArrayList();
//往集合中添加元素,返回值的意思是 是否添加成功
boolean b = collection.add("aaa");
collection.add("bbb");
collection.add("ccc");
Collection collection1 = new ArrayList();
collection1.add(100); //自动装箱
collection1.add(Integer.valueOf(20));
collection1.add(300);
collection1.add(400);
boolean b1 = collection.addAll(collection1);
System.out.println(collection);
System.out.println(collection1);
}
}
import java.util.ArrayList;
import java.util.Collection;
public class MyTest {
public static void main(String[] args) {
Collection collection1 = new ArrayList();
collection1.add(100); //自动装箱
collection1.add(Integer.valueOf(20));
collection1.add(300);
collection1.add(400);
//删掉集合中的元素
boolean b = collection1.remove(400);
System.out.println(collection1);
//清空集合中集合中的元素
collection1.clear();
System.out.println(collection1);
}
}
import java.util.ArrayList;
import java.util.Collection;
public class MyTest2 {
public static void main(String[] args) {
Collection collection1 = new ArrayList();
collection1.add(1000); //自动装箱
collection1.add(2000);
collection1.add(3000);
collection1.add(4000);
collection1.add(4000);
collection1.add(500);
Collection collection2 = new ArrayList();
collection2.add(100); //自动装箱
collection2.add(200);
collection2.add(300);
collection2.add(400);
//A集合removeAll(B集合) A 集合会移除掉两个集合的交集元素,如果移除了返回true,没有交集元素返回false
boolean b = collection1.removeAll(collection2);
System.out.println(b);
System.out.println(collection1);
System.out.println(collection2);
}
}
import java.util.ArrayList;
import java.util.Collection;
public class MyTest3 {
public static void main(String[] args) {
//与判断相关的方法
Collection collection1 = new ArrayList();
collection1.add(1000); //自动装箱
collection1.add(2000);
collection1.add(3000);
collection1.add(4000);
collection1.add(4000);
collection1.add(500);
//判断集合中是否有这个元素
boolean b = collection1.contains(5000);
System.out.println(b);
}
}
import jdk.management.resource.internal.inst.SocketOutputStreamRMHooks;
import java.util.ArrayList;
import java.util.Collection;
public class MyTest4 {
public static void main(String[] args) {
Collection collection1 = new ArrayList();
collection1.add(100); //自动装箱
collection1.add(200);
collection1.add(300);
collection1.add(400);
collection1.add(4000);
collection1.add(500);
Collection collection2 = new ArrayList();
collection2.add(100); //自动装箱
collection2.add(200);
collection2.add(300);
collection2.add(400);
collection2.add(600);
// [1,2,3]containsAll([1,2,4]) //false
// [1, 2, 3,4]containsAll([1, 2, 4]) //true
boolean b = collection1.containsAll(collection2);
System.out.println(b);
}
}
import java.util.ArrayList;
import java.util.Collection;
public static void main(String[] args) {
Collection collection1 = new ArrayList();
collection1.add(1000); //自动装箱
collection1.add(2000);
collection1.add(3000);
collection1.add(4000);
collection1.add(4000);
collection1.add(500);
//获取集合的长度
int size = collection1.size();
System.out.println(size);
collection1.clear();
//判断一个集合是否为空
boolean empty = collection1.isEmpty();
System.out.println(empty);
// "".isEmpty();
}
}
迭代器
使用迭代器对集合进行遍历
import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
public class MyTest {
public static void main(String[] args) {
Collection collection1 = new ArrayList();
collection1.add(1000); //自动装箱
collection1.add(2000);
collection1.add(3000);
collection1.add(4000);
collection1.add(4000);
collection1.add(500);
//遍历Collection集合需要获取一个迭代器
//对 collection 进行迭代的迭代器
/* boolean hasNext ()
如果仍有元素可以迭代,则返回 true。
E next ()
返回迭代的下一个元素。*/
// 接口 Iterator<E >
Iterator iterator = collection1.iterator();
//java.util.ArrayList$Itr @ 1 b6d3586
Object next = iterator.next();//手动移动
System.out.println(next);
System.out.println(iterator);
while (iterator.hasNext()){
Object obj= iterator.next();
System.out.println(obj);
}
}
}
List集合
List集合的特有功能概述
void add(int index,E element): 在指定索引处添加元素
E remove(int index):移除指定索引处的元素 返回的是移除的元素
E get(int index):获取指定索引处的元素
E set(int index,E element):更改指定索引处的元素 返回的而是被替换的元素
功能演示
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Iterator;
public class MyTest {
public static void main(String[] args) {
Collection collection1 = new ArrayList();
collection1.add(1000); //自动装箱
collection1.add(2000);
collection1.add(3000);
collection1.add(4000);
collection1.add(4000);
collection1.add(500);
//把一个集合转换成数组
//toArray();把一个集合转换成数组
Object[] objects = collection1.toArray();
//遍历途中可以对元素进行向下转型
for (int i = 0; i < objects.length; i++) {
Integer object = (Integer) objects[i];
System.out.println(object.intValue());
}
}
}
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
public class MyTest2 {
public static void main(String[] rgs) {
List list = new ArrayList();
list.add(1000); //自动装箱
list.add(2000);
list.add(3000);
list.add(4000);
list.add(4000);
list.add(500);
//在指定索引处添加元素
list.add(0,20000);
System.out.println(list);
//根据索引获取元素
Object o = list.get(list.size() - 1);
System.out.println(o);
//根据起始索引,终止索引,截取一段元素放到新集合中
List list1 = list.subList(2, 4);
System.out.println(list1);
list.set(list.size()-1,5000); //根据索引,修改元素
System.out.println(list);
list.remove(2);
list.remove(Integer.valueOf(2000)); //假如是Integer类型,我要删除的时候,区分不出来 索引和对象了
//如果你要根据元素删,你就把元素手动包装一下
System.out.println(list);
}
}
List有自己专用的迭代器
import java.util.ArrayList;
import java.util.List;
import java.util.ListIterator;
public class MyTest3 {
public static void main(String[] args) {
List list = new ArrayList();
list.add(1000); //自动装箱
list.add(2000);
list.add(3000);
list.add(4000);
list.add(4000);
list.add(500);
//遍历方式1
//list.iterator()
//遍历方式2:List 有一个自己的迭代器
ListIterator listIterator = list.listIterator();
while (listIterator.hasNext()){
Object next = listIterator.next();
System.out.println(next);
}
System.out.println("==============================");
//遍历方式3 采用for循环遍历
for (int i = 0; i < list.size(); i++) {
Object o = list.get(i);
System.out.println(o);
}
}
}
ListIterator的特有功能
ListIterator 继承自Iterator 可以使用Iterator中的方法
A:ListIterator的特有功能
boolean hasPrevious(): 是否存在前一个元素
E previous(): 返回列表中的前一个元素
以上两个方法可以实现反向遍历 但是注意 要完成反向遍历之前 要先进行正向遍历 这样指针才能移到最后
如果直接反向遍历是没有效果的 因为指针默认位置就在最前面 他前面没有元素
并发修改异常产生的原因及解决方案
ConcurrentModificationException出现
我们用Iterator这个迭代器遍历采用hasNext方法和next方法,集合修改集合 会出现并发修改异常
原因是我们的迭代依赖与集合 当我们往集合中添加好了元素之后 获取迭代器 那么迭代器已经知道了集合的元素个数
这个时候你在遍历的时候又突然想给 集合里面加一个元素(用的是集合的add方法) 那迭代器不同意 就报错了
解决方案1 我们用ListIterator迭代器遍历 用迭代器自带的add方法添加元素 那就不会报错了
a:迭代器迭代元素,迭代器修改元素(ListIterator的特有功能add)
b:集合遍历元素,集合修改元素
解决方案2 使用for循环遍历集合 添加元素 不会报错
List的三个子类的特点
ArrayList:
底层数据结构是数组,查询快,增删慢。
线程不安全,效率高。
Vector:
底层数据结构是数组,查询快,增删慢。
线程安全,效率低。
LinkedList:
底层数据结构是链表,查询慢,增删快。
线程不安全,效率高。
用哪个 得看 要安全还是要效率
是查找多还是增删多
数据结构
数据结构概述及常见数据结构
数据结构其实就是存储数据的格式
分类: 栈 , 队列 , 数组 , 链表 , 树 , 哈希表
栈特点: 先进后出
队列: 先进先出
数据结构之数组和链表
数组特点: 查询快 , 增删慢
链表特点: 查询慢 , 增删快