版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
###16.01_集合框架(去除ArrayList中重复字符串元素方式)(掌握)
- A:案例演示
- 需求:ArrayList去除集合中字符串的重复值(字符串的内容相同)
- 思路:创建新集合方式
import java.util.ArrayList;
import java.util.Iterator;
public class Main {
public static void main(String[] args) {
ArrayList list = new ArrayList();
list.add("a");
list.add("b");
list.add("b");
list.add("c");
list.add("c");
list.add("c");
System.out.println(list);//[a, b, b, c, c, c]
ArrayList newList = getList(list);
System.out.println(newList);//[a, b, c]
}
/**
* 创建新集合将重复元素去掉
* 1.明确返回值类型,返回ArrayList
* 2.明确参数列表ArrayList
*
* 1.创建新集合
* 2.根据传入的老集合获取迭代器
* 3.遍历老集合
* 4.通过新集合判断是否包含老集合中的元素,包含就不添加,不包含就添加
*/
public static ArrayList getList(ArrayList list){
ArrayList newList = new ArrayList();
Iterator it = list.iterator();
while(it.hasNext()){
Object obj = it.next();
if(!newList.contains(obj)){
newList.add(obj);
}
}
return newList;
}
}
/**
* A:案例演示
* 需求:ArrayList去除集合中字符串的重复值(字符串的内容相同)
* 思路:创建新集合方式
*/
public static void main(String[] args) {
ArrayList list = new ArrayList();
list.add("a");
list.add("a");
list.add("b");
list.add("b");
list.add("b");
list.add("c");
list.add("c");
list.add("c");
list.add("c");
System.out.println(list);
ArrayList newList = getSingle(list);
System.out.println(newList);
}
/*
* 去除重复
* 1,返回ArrayList
* 2,参数列表ArrayList
*/public static ArrayList getSingle(ArrayList list) {
ArrayList newList = new ArrayList(); //创建一个新集合
Iterator it = list.iterator(); //获取迭代器
while(it.hasNext()) { //判断老集合中是否有元素
String temp = (String)it.next(); //将每一个元素临时记录住
if(!newList.contains(temp)) { //如果新集合中不包含该元素
newList.add(temp); //将该元素添加到新集合中
}
}
return newList; //将新集合返回
}
###16.02_集合框架(去除ArrayList中重复自定义对象元素)(掌握)
- A:案例演示
- 需求:ArrayList去除集合中自定义对象元素的重复值(对象的成员变量值相同)
- B:注意事项
- contains方法判断是否包含时底层依赖的是equals方法
- remove方法判断是否删除底层依赖的也是equals方法
- 重写equals()方法的
public class Person {
private String name;
private int age;
public Person(){
super();
}
public Person(String name, int age){
super();
this.name = name;
this.age = age;
}
public String getName(){
return name;
}
public void setName(){
this.name = name;
}
public int getAge(){
return age;
}
public void setAge(int age){
this.age = age;
}
public String toString(){
return "Person [name=" + name +", age=" + age + "]";
}
//重写equals方法
public boolean equals(Object obj){
Person p = (Person)obj;
return this.name.equals(p.name) && this.age==p.age;
}
}
import java.util.ArrayList;
import java.util.Iterator;
public class Main {
public static void main(String[] args) {
ArrayList list = new ArrayList();
list.add(new Person("张三",21));
list.add(new Person("李四",22));
list.add(new Person("李四",22));
list.add(new Person("王五",23));
list.add(new Person("王五",23));
list.add(new Person("王五",23));
System.out.println(list);
ArrayList newList = getList(list);
System.out.println(newList);//结果和list一样
//因为getList中的contain依赖的是equals来判断
//而Object中的equals判断的是地址值,每个对象的地址值均不同,所以均保留
//因此要重写equals方法
//在Person类中重写equals方法后结果正确
//[Person [name=张三, age=21], Person [name=李四, age=22], Person [name=王五, age=23]]
}
/**
* 创建新集合将重复元素去掉
* 1.明确返回值类型,返回ArrayList
* 2.明确参数列表ArrayList
*
* 1.创建新集合
* 2.根据传入的老集合获取迭代器
* 3.遍历老集合
* 4.通过新集合判断是否包含老集合中的元素,包含就不添加,不包含就添加
*/
public static ArrayList getList(ArrayList list){
ArrayList newList = new ArrayList();
Iterator it = list.iterator();
while(it.hasNext()){
Object temp = it.next();
if(!newList.contains(temp)){
newList.add(temp);
}
}
return newList;
}
}
###16.03_集合框架(LinkedList的特有功能)(掌握)
- A:LinkedList类概述
- B:LinkedList类特有功能
- public void addFirst(E e)及addLast(E e) 头添加和尾添加
- public E getFirst()及getLast() 获取第一个元素和获取最后一个元素
- public E removeFirst()及public E removeLast() 删除头和删除尾
- public E get(int index); 获取索引对应的值
import java.util.LinkedList;
public class Main {
public static void main(String[] args) {
LinkedList list = new LinkedList();
list.addFirst("a");//头添加
list.addFirst("b");//头添加
list.addFirst("c");//头添加
list.addLast("d");//尾添加
System.out.println(list);
System.out.println(list.getFirst());//获取头部
System.out.println(list.getLast());//获取尾部
list.removeFirst();//删除头
list.removeLast();//删除尾
System.out.println(list);
System.out.println(list.get(1));//获取相应索引位置的元素
//虽然LinkedList也可以通过索引获取元素值,但它的底层实现相对ArrayList比较复杂
}
}
###16.04_集合框架(栈和队列数据结构)(掌握)
- 栈
- 先进后出
- 队列
- 先进先出
###16.05_集合框架(用LinkedList模拟栈数据结构的集合并测试)(掌握)
- A:案例演示
- 需求:请用LinkedList模拟栈数据结构的集合,并测试
- 创建一个类将Linked中的方法封装
- 栈先进后出
- 进相当于addLast添加在最后面,出相当于removeLast后面的先出
import java.util.LinkedList;
public class Main {
public static void main(String[] args) {
LinkedList list = new LinkedList();
list.addLast("a"); //用addLast方法模拟进栈
list.addLast("b");
list.addLast("c");
list.addLast("d");
while(!list.isEmpty()){
System.out.println(list.removeLast());//模拟出栈
// d c b a
}
}
}
- 更好的方法
//用LinkedList模拟栈结构
//实际上就是对LinkedList进行封装,改名
import java.util.LinkedList;
public class Stack {
private LinkedList list = new LinkedList();//创建LinkedList对象
//模拟进栈方法 封装addLast方法
public void in(Object obj){
list.addLast(obj);
}
//模拟出栈方法 封装removeLast方法
public Object out(){
return list.removeLast();
}
//模拟栈结构是否为空 封装isEmpty方法
public boolean isEmpty(){
return list.isEmpty();
}
}
public class Main {
public static void main(String[] args) {
Stack s = new Stack();
s.in("a"); //进栈
s.in("b");
s.in("c");
while(!s.isEmpty()){ //判断栈结构是否为空
System.out.println(s.out());//弹栈 c b a
}
}
}
- 队列结构同栈结构差不多,只是把removeLast改成removeFirst,先进的先出
###16.06_集合框架(泛型概述和基本使用)(掌握)
- A:泛型概述
- B:泛型好处
- 提高安全性(将运行期的错误转换到编译期)
- 省去强转的麻烦
- C:泛型基本使用
- <>中放的必须是引用数据类型
- D:泛型使用注意事项
- 前后的泛型必须一致,或者后面的泛型可以省略不写(1.7的新特性菱形泛型)
- 加object泛型没有意义
- 当没有用到泛型时
import java.util.ArrayList;
import java.util.Iterator;
public class Main {
public static void main(String[] args) {
ArrayList list = new ArrayList();
list.add(10);
list.add(true);
list.add(new Person("张三",23));
Iterator it = list.iterator();
while(it.hasNext()){
Person p = (Person)it.next(); //向下转型
System.out.println(p.getName()+p.getAge());
//报错误ClassCastException,强转的类型不满足该类型 age不能转String
}
}
}
import java.util.ArrayList;
import java.util.Iterator;
public class Main {
public static void main(String[] args) {
ArrayList<Person> list = new ArrayList<Person>();
// list.add(10); //里面是Person告诉我们只能是Person
// list.add(true);
list.add(new Person("张三",23));
Iterator<Person> it = list.iterator();//存储的是Person因此迭代的也是Person
while(it.hasNext()){
Person p = it.next(); //不用再强转了
// next方法只能调用一次,若调用多次会在将指针后移多次,所以需要创建Person对象
System.out.println(p.getName()+" "+p.getAge());
//张三 23
}
}
}
###16.07_集合框架(ArrayList存储字符串和自定义对象并遍历泛型版)(掌握)
- A:案例演示
- ArrayList存储字符串并遍历泛型版
import java.util.ArrayList;
import java.util.Iterator;
public class Main {
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<>();//创建集合对象
list.add("a");
list.add("b");
list.add("c");
Iterator<String> it = list.iterator();
while(it.hasNext()){
System.out.println(it.next());
}
}
}
import java.util.ArrayList;
import java.util.Iterator;
public class Main {
public static void main(String[] args) {
ArrayList<Person> list= new ArrayList<>();
list.add(new Person("张三",23));
list.add(new Person("李四",24));
list.add(new Person("王五",25));
Iterator<Person> it = list.iterator();
while(it.hasNext()){
Person p = it.next();
System.out.println(p.getName()+" "+p.getAge());
//张三 23
//李四 24
//王五 25
}
}
}
###16.08_集合框架(泛型的由来)(了解)
- A:案例演示
- 泛型的由来:通过Object转型问题引入
- 早期的Object类型可以接收任意的对象类型,但是在实际的使用中,会有类型转换的问题。也就存在这隐患,所以Java提供了泛型来解决这个安全问题。
public static void main(String[] args) {
//demo1();
Tool<String> t = new Tool<>();
//t.show("abc");
t.show(true);
}
public static void demo1() {
Tool<Student> t = new Tool<>(); //创建工具类对象
t.setObj(new Student("张三",23));
//Worker w = (Worker) t.getObj(); //向下转型
//System.out.println(w);
}
###16.09_集合框架(泛型类的概述及使用)(了解)
- A:泛型类概述
- 把泛型定义在类上
- B:定义格式
- public class 类名<泛型类型1,…>
- C:注意事项
- 泛型类型必须是引用类型
- D:案例演示
- 泛型类的使用
public class Tool<Q> {
private Q q;
public Q getObj() {
return q;
}
public void setObj(Q q) {
this.q = q;
}
}
###16.10_集合框架(泛型方法的概述和使用)(了解)
- A:泛型方法概述
- 把泛型定义在方法上
- B:定义格式
- public <泛型类型返回类型 方法名(泛型类型 变量名)
- C:案例演示
- 泛型方法的使用
public class Tool<Q> {
private Q q;
public Q getObj() {
return q;
}
public void setObj(Q q) {
this.q = q;
}
public<T> void show(T t) { //方法泛型最好与类的泛型一致
System.out.println(t); //如果不一致,需要在方法上声明该泛型
}
public static<W> void print(W w) { //静态方法必须声明自己的泛型
System.out.println(w);
}
}
###16.11_集合框架(泛型接口的概述和使用)(了解)
- A:泛型接口概述
- 把泛型定义在接口上
- B:定义格式
- public interface 接口名<泛型类型>
- C:案例演示
- 泛型接口的使用
- 方法一
public class Main {
public static void main(String[] args) {
}
interface Inter<T>{
public void show(T t);
}
class Demo implements Inter<String>{
@Override
public void show(String t) {
System.out.println(t);
}
}
}
- 方法二
public class Main {
public static void main(String[] args) {
}
interface Inter<T>{
public void show(T t);
}
class Demo<T> implements Inter<T>{ //没有必要在实现接口的时候给自己类加泛型
@Override
public void show(T t) {
System.out.println(t);
}
}
}
###16.12_集合框架(泛型高级之通配符)(了解)
- A:泛型通配符<?>
- 任意类型,如果没有明确,那么就是Object以及任意的Java类了
List<?> list = new ArrayList<Integer>();
//当右边的泛型不确定时,左边可以指定为?
- B:? extends E
- 向下限定,E及其子类
- C:? super E
- 向上限定,E及其父类
###16.13_集合框架(增强for的概述和使用)(掌握)
- A:增强for概述
- 简化数组和Collection集合的遍历
- B:格式:
for(元素数据类型 变量 : 数组或者Collection集合) {
使用变量即可,该变量就是元素
}
- C:案例演示
- 数组,集合存储元素用增强for遍历
import java.util.ArrayList;
public class Main {
public static void main(String[] args) {
int arr[] = {11,22,33,44,55};
for(int i : arr){
System.out.println(i);
// 11 22 33 44 55
}
ArrayList<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
for (String string : list) {
System.out.println(string);
// a b c
}
}
}
- D:好处
- 简化遍历
- 增强for循环,底层依赖的是迭代器
###16.14_集合框架(ArrayList存储字符串和自定义对象并遍历增强for版)(掌握)
- A:案例演示
- ArrayList存储字符串并遍历增强for版
ArrayList<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
list.add("d");
for(String s : list) {
System.out.println(s);
}
###16.15_集合框架(三种迭代的能否删除)(掌握)
- 普通for循环,可以删除,但是索引要–
- 迭代器,可以删除,但是必须使用迭代器自身的remove方法,否则会出现并发修改异常
- 增强for循环不能删除
public static void main(String[] args) {
//demo1();
//demo2();
ArrayList<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("b");
list.add("c");
list.add("d");
//1,普通for循环删除,索引要--
/*for(int i = 0; i < list.size(); i++) {
if("b".equals(list.get(i))) {
list.remove(i--); //通过索引删除元素
}
}*/
//2,迭代器删除
/*Iterator<String> it = list.iterator();
while(it.hasNext()) {
if("b".equals(it.next())) {
//list.remove("b");
//不能用集合的删除方法,因为迭代过程中如果集合修改会出现并发修改异常
it.remove();
}
}*/
/*for(Iterator<String> it2 = list.iterator(); it2.hasNext();) {
if("b".equals(it2.next())) {
//list.remove("b");
//不能用集合的删除方法,因为迭代过程中如果集合修改会出现并发修改异常
it2.remove();
}
}*/
//3,增强for循环,增强for循环不能删除,只能遍历
for (String string : list) {
if("b".equals(string)) {
list.remove("b");
}
}
System.out.println(list);
}
###16.16_集合框架(静态导入的概述和使用)(了解)
- A:静态导入概述:导入类中的静态方法
- B:格式:
- import static 包名….类名.方法名;
- 可以直接导入到方法的级别
- C:注意事项
- 方法必须是静态的,如果有多个同名的静态方法,容易不知道使用谁?
- 这个时候要使用,必须加前缀。由此可见,意义不大,所以一般不用,但是要能看懂。
import static java.util.Arrays.sort; //静态导入
import static java.util.Arrays.toString; //静态导入
public class Demo2_StaticImport {
/**
* * A:静态导入概述
* 静态导入是导入类中静态方法
* B:格式:
* import static 包名….类名.方法名;
* 可以直接导入到方法的级别
* C:注意事项
* 方法必须是静态的,如果有多个同名的静态方法,容易不知道使用谁?这个时候要使用,必须加前缀。由此可见,意义不大,所以一般不用,但是要能看懂。
静态导入开发不用,但是需要能看懂
*/
public static void main(String[] args) {
int[] arr = {55,22,33,44,11};
sort(arr); //排序
//System.out.println(toString(arr));
}
}
###16.17_集合框架(可变参数的概述和使用)(掌握)
- A:可变参数概述
- 定义方法的时候不知道该定义多少个参数
- B:格式
- 修饰符 返回值类型 方法名(数据类型… 变量名){}
- C:注意事项:
- 这里的变量其实是一个数组
- 如果一个方法有可变参数,并且有多个参数,那么,可变参数肯定是最后一个
public class Demo3_ChangeableArgs {
/**
* * A:可变参数概述
* 定义方法的时候不知道该定义多少个参数
* B:格式
* 修饰符 返回值类型 方法名(数据类型… 变量名){}
* C:注意事项:
* 这里的变量其实是一个数组
* 如果一个方法有可变参数,并且有多个参数,那么,可变参数肯定是最后一个
*/
public static void main(String[] args) {
int[] arr = {11,22,33,44,55};
//print(arr);
print(11,22,33,44,55);
System.out.println("---------------");
//print();
}
/*public static void print(int[] arr) {
for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
}
}*/
public static void print(int ... arr) { //可变参数其实是一个数组
for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
}
}
}
###16.18_集合框架(Arrays工具类的asList()方法的使用)(掌握)
- A:案例演示
- 将数组转换成集合
- Arrays工具类的asList()方法的使用
- Collection中toArray(T[] a)泛型版的集合转数组
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class Demo4_AsList {
/**
* 数组转换成集合
* 数组转换成集合虽然不能增加或减少元素,
* 但是可以用集合的思想操作数组,也就是说可以使用其他集合中的方法
*/
public static void main(String[] args) {
//demo1();
//demo2();
//集合转数组,加泛型的
ArrayList<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
list.add("d");
String[] arr = list.toArray(new String[10]);
//当集合转换数组时,数组长度如果是小于等于集合的size时,
//转换后的数组长度等于集合的size
//如果数组的长度大于了size,分配的数组长度就和你指定的长度一样
for (String string : arr) {
System.out.println(string);
}
}
public static void demo2() {
//int[] arr = {11,22,33,44,55};
//List<int[]> list = Arrays.asList(arr);
//基本数据类型的数组转换成集合,会将整个数组当作一个对象转换
//System.out.println(list);
Integer[] arr = {11,22,33,44,55};
//将数组转换成集合,数组必须是引用数据类型
List<Integer> list = Arrays.asList(arr);
System.out.println(list);
}
public static void demo1() {
String[] arr = {"a","b","c"};
List<String> list = Arrays.asList(arr); //将数组转换成集合
//list.add("d"); //不能添加和减少
System.out.println(list);
}
}
###16.19_集合框架(集合嵌套之ArrayList嵌套ArrayList)(掌握)
- A:案例演示
- 集合嵌套之ArrayList嵌套ArrayList。
import java.util.ArrayList;
import com.heima.bean.Person;
public class Demo5_ArrayListArrayList {
/**
* * A:案例演示
* 集合嵌套之ArrayList嵌套ArrayList
* 案例:
* 我们学科,学科又分为若个班级
* 整个学科一个大集合
* 若干个班级分为每一个小集合
*/
public static void main(String[] args) {
ArrayList<ArrayList<Person>> list = new ArrayList<>();
ArrayList<Person> first = new ArrayList<>(); //创建第一个班级
first.add(new Person("杨幂", 30));
first.add(new Person("李冰冰", 33));
first.add(new Person("范冰冰", 20));
ArrayList<Person> second = new ArrayList<>();
second.add(new Person("黄晓明", 31));
second.add(new Person("赵薇", 33));
second.add(new Person("陈坤", 32));
//将班级添加到学科集合中
list.add(first);
list.add(second);
//遍历学科集合
for(ArrayList<Person> a : list) {
for(Person p : a) {
System.out.println(p);
}
}
}
}