day16<集合框架+>

时间:2023-03-09 03:55:00
day16<集合框架+>

集合框架(去除ArrayList中重复字符串元素方式)

集合框架(去除ArrayList中重复自定义对象元素)

集合框架(LinkedList的特有功能)

集合框架(栈和队列数据结构)

集合框架(用LinkedList模拟栈数据结构的集合并测试)

集合框架(泛型(generic)概述和基本使用)

集合框架(ArrayList存储字符串和自定义对象并遍历泛型版)

集合框架(泛型的由来)

集合框架(泛型类的概述及使用)

集合框架(泛型方法的概述和使用)

集合框架(泛型接口的概述和使用)

集合框架(泛型高级之通配符)

集合框架(增强for的概述和使用)

集合框架(ArrayList存储自定义对象并遍历增强for版)

集合框架(三种迭代的能否删除)

集合框架(静态导入的概述和使用)

集合框架(可变参数的概述和使用)

集合框架(Arrays工具类的asList()方法的使用)

集合框架(集合嵌套之ArrayList嵌套ArrayList)

 

###16.01_集合框架(去除ArrayList中重复字符串元素方式)(掌握)
 A:案例演示
     需求:ArrayList去除集合中字符串的重复值(字符串的内容相同)
     思路:创建新集合方式

public class Demo1_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("c");

list.add("c");

ArrayList newList = getSingle(list);

System.out.println(newList); //[a, b, c]

}

/*

* 创建新集合将重复元素去掉

* 1,明确返回值类型,返回ArrayList

* 2,明确参数列表ArrayList

*

* 分析:

* 1,创建新集合

* 2,根据传入的集合(老集合)获取迭代器

* 3,遍历老集合

* 4,通过新集合判断是否包含老集合中的元素,如果包含就不添加,如果不包含就添加

*/

    public static ArrayList getSingle(ArrayList list) {

ArrayList newList = new ArrayList(); //1,创建新集合

Iterator it = list.iterator(); //2,根据传入的集合(老集合)获取迭代器

while(it.hasNext()) { //3,遍历老集合

Object obj = it.next(); //记录住每一个元素

   if(!newList.contains(obj)) { //如果新集合中不包含老集合中的元素

newList.add(obj); //将该元素添加

}

}

       return newList;

}

}

###16.02_集合框架(去除ArrayList中重复自定义对象元素)(掌握)
 A:案例演示
     需求:ArrayList去除集合中自定义对象元素的重复值(对象的成员变量值相同)
 B:注意事项
     重写equals()方法的

@Override

    public boolean equals(Object obj) {

Person p = (Person)obj;

return this.name.equals(p.name) && this.age == p.age;

}

public class Demo2_ArrayList {

/**

contains方法判断是否包含,底层依赖的是equals方法

remove方法判断是否删除,底层依赖的是equals方法,没重写前比较的是地址值,重写后比较对象的属性值

*/

    public static void main(String[] args) {

ArrayList list = new ArrayList(); //创建集合对象

list.add(new Person("张三", 23));

list.add(new Person("张三", 23));

list.add(new Person("李四", 24));

list.add(new Person("李四", 24));

//ArrayList newList = getSingle(list); //调用方法去除重复

//System.out.println(newList);

list.remove(new Person("张三", 23));

System.out.println(list); //重写后比较对象的属性,所以没重写equals方法比较的是地址值,删不了

}

/*

* 创建新集合将重复元素去掉

* 1,明确返回值类型,返回ArrayList

* 2,明确参数列表ArrayList

*

* 分析:

* 1,创建新集合

* 2,根据传入的集合(老集合)获取迭代器

* 3,遍历老集合

* 4,通过新集合判断是否包含老集合中的元素,如果包含就不添加,如果不包含就添加

*/

    public static ArrayList getSingle(ArrayList list) {

ArrayList newList = new ArrayList(); //1,创建新集合

Iterator it = list.iterator(); //2,根据传入的集合(老集合)获取迭代器

while(it.hasNext()) { //3,遍历老集合

Object obj = it.next(); //记录住每一个元素

   if(!newList.contains(obj)) { //如果新集合中不包含老集合中的元素

newList.add(obj); //将该元素添加

}

}

       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);

LinkedList list = new LinkedList();

list.addFirst("a");

list.addFirst("b");

list.addLast("c");

System.out.println(list.getFirst()); //b

System.out.println(list.getLast()); //c

System.out.println(list.removeFirst()); //b

System.out.println(list.removeLast()); //c

System.out.println(list.get(1)); //a

System.out.println(list); //[b, a, c]

###16.04_集合框架(栈和队列数据结构)(掌握)
 栈
     先进后出 
 队列
     先进先出

###16.05_集合框架(用LinkedList模拟栈数据结构的集合并测试)(掌握)
 A:案例演示
     需求:请用LinkedList模拟栈数据结构的集合,并测试
     创建一个类将Linked中的方法封装

public class Stack {

    private LinkedList list = new LinkedList();

// 模拟进栈方法

public void in(Object obj) {

list.addLast(obj);

}

// 模拟出栈

    public Object out() {

return list.removeLast();

}

// 模拟栈结构是否为空

    public boolean isEmpty() {

return list.isEmpty();

}

}

//用LinkedList模拟栈结构

    public static void main(String[] args) {

//demo1();

Stack s = new Stack();

s.in("a"); //进栈

s.in("b");

s.in("c");

s.in("d");

while(!s.isEmpty()) { //判断栈结构是否为空

System.out.println(s.out()); //弹栈

}

}

    public static void demo1() {

LinkedList list = new LinkedList(); //创建集合对象

list.addLast("a");

list.addLast("b");

list.addLast("c");

list.addLast("d");

/*System.out.println(list.removeLast());

System.out.println(list.removeLast());

System.out.println(list.removeLast());

System.out.println(list.removeLast());*/

while(!list.isEmpty()) {

System.out.println(list.removeLast());

}

}

###16.06_集合框架(泛型概述和基本使用)(掌握)
 A:泛型概述
 B:泛型好处
     提高安全性(将运行期的错误转换到编译期) 
     省去强转的麻烦
 C:泛型基本使用
     <>中放的必须是引用数据类型 
 D:泛型使用注意事项
     前后的泛型必须一致,或者后面的泛型可以省略不写(1.7的新特性菱形泛型)

    public static void main(String[] args) {

demo1();

//int[] arr = new byte[5]; //数组要保证前后的数据类型一致

//ArrayList<Object> list = new ArrayList<Person>(); //集合的泛型要保证前后的数据类型一致

//ArrayList<Object> list = new ArrayList<>();//1.7版本的新特性,菱形泛型

ArrayList<Object> list = new ArrayList<Object>(); //泛型最好不要定义成Object,没有意义

list.add("aaa");

list.add(true);

}

    public static void demo1() {

ArrayList<Person> list = new ArrayList<Person>();

// list.add(110);

// list.add(true);

list.add(new Person("张三", 23));

list.add(new Person("李四", 24));

Iterator<Person> it = list.iterator();

while(it.hasNext()) {

//System.out.println(it.next());

//System.out.println(it.next().getName() + "..." + it.next().getAge());//张三...24 //next方法只能调用一次,如果调用多次会将指针向后移动多次

Person p = it.next();

System.out.println(p.getName() + "..." + p.getAge());

}

}

###16.07_集合框架(ArrayList存储字符串和自定义对象并遍历泛型版)(掌握)
 A:案例演示
     ArrayList存储字符串并遍历泛型版

    public static void main(String[] args) {

//demo1();

ArrayList<Person> list = new ArrayList<Person>();

list.add(new Person("张三", 23));

list.add(new Person("李四", 24));

list.add(new Person("王五", 25));

list.add(new Person("赵六", 26));

Iterator<Person> it = list.iterator();

while(it.hasNext()) {

Person p = it.next(); //将集合中的每一个元素用Person记录

System.out.println(p.getName() + "..." + p.getAge());

}

}

    public static void demo1() {

ArrayList<String> list = new ArrayList<String>(); //创建集合对象

list.add("a");

list.add("b");

list.add("c");

list.add("d");

Iterator<String> it = list.iterator();

while(it.hasNext()) {

System.out.println(it.next());

}

}

###16.08_集合框架(泛型的由来)(了解)
 A:案例演示
     泛型的由来:通过Object转型问题引入
     早期的Object类型可以接收任意的对象类型,但是在实际的使用中,会有类型转换的问题。也就存在这隐患,所以Java提供了泛型来解决这个安全问题。

###16.09_集合框架(泛型类的概述及使用)(了解)
 A:泛型类概述<T>
     把泛型定义在类上
 B:定义格式
     public class 类名<泛型类型1,…>
 C:注意事项    
     泛型类型必须是引用类型
 D:案例演示
     泛型类的使用

public class Tool<Q> { //泛型一个字母大写,当用Tool创建对象时指定泛型,指定泛型是什么这个Q就是什么

    private Q q;

    public Q getObj() {

return q;

}

    public void setObj(Q q) {

        this.q = q;

}

}

public static void main(String[] args) {

Tool<Student> t = new Tool<Student>(); //创建工具类对象

t.setObj(new Student("张三",23));

//Worker w = (Worker) t.getObj(); //向下转型

//System.out.println(w);

}

###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); //如果不一致,需要在方法上声明该泛型

}

//Static方法随类的加载而加载,加载时可能还没创建对象Q没值

    public static<W> void print(W w) { //静态方法必须声明自己的泛型

System.out.println(w);

}

}

    public static void main(String[] args) {

//demo1();

Tool<String> t = new Tool<String>();//创建工具类对象指定为String类型

//t.show("abc");

t.show(true);

}

    public static void demo1() {

Tool<Student> t = new Tool<Student>(); //创建工具类对象

t.setObj(new Student("张三",23));

//Worker w = (Worker) t.getObj(); //向下转型

//System.out.println(w);

}

###16.11_集合框架(泛型接口的概述和使用)(了解)
 A:泛型接口概述
     把泛型定义在接口上
 B:定义格式    
     public interface 接口名<泛型类型>
 C:案例演示
     泛型接口的使用

interface Inter<T> {

    public void show(T t);

}

class Demo implements Inter<String> { //推荐用这种

@Override

    public void show(String t) {

System.out.println(t);

}

}

class Demo<T> implements Inter<T> { //没有必要在实现接口的时候给自己类加泛型

@Override

    public void show(T t) {

System.out.println(t);

}

}

###16.12_集合框架(泛型高级之通配符)(了解)
 A:泛型通配符<?>
     任意类型,如果没有明确,那么就是Object以及任意的Java类了
 B:? extends E
     向下限定,E及其子类
 C:? super E
     向上限定,E及其父类

//List<?> list = new ArrayList<Integer>(); //当右边的泛型是不确定时,左边可以指定为?

ArrayList<Person> list1 = new ArrayList<Person>();

list1.add(new Person("张三", 23));

list1.add(new Person("李四", 24));

list1.add(new Person("王五", 25));

ArrayList<Student> list2 = new ArrayList<Student>();

list2.add(new Student("赵六", 26));

list2.add(new Student("周七", 27));

list1.addAll(list2); //Student必须继承Person才能放进去

System.out.println(list1);

###16.13_集合框架(增强for的概述和使用)(掌握)
 A:增强for概述
     简化数组和Collection集合的遍历
 B:格式:
        for(元素数据类型 变量 : 数组或者Collection集合) {
            使用变量即可,该变量就是元素
        }
 C:案例演示
     数组,集合存储元素用增强for遍历

ArrayList存储字符串并遍历增强for版
 D:好处
     简化遍历

    int[] arr = {11,22,33,44,55};

    for (int i : arr) {

System.out.println(i);

}

ArrayList<String> list = new ArrayList<String>();

list.add("a");

list.add("b");

list.add("c");

list.add("d");

    for (String string : list) {

System.out.println(string);

}

###16.14_集合框架(ArrayList存储字符串和自定义对象并遍历增强for版)(掌握)
 A:案例演示
     自定义对象并遍历增强for版
     增强for循环底层依赖的是迭代器(Iterator)

ArrayList<Person> list = new ArrayList<Person>();

list.add(new Person("张三", 23));

list.add(new Person("李四", 24));

list.add(new Person("王五", 25));

list.add(new Person("赵六", 26));

    for (Person person : list) {

System.out.println(person);

}

###16.15_集合框架(三种迭代的能否删除)(掌握)
     普通for循环,可以删除,但是索引要--
     迭代器,可以删除,但是必须使用迭代器自身的remove方法,否则会出现并发修改异常
     jdk1.5增强for循环不能删除

ArrayList<String> list = new ArrayList<String>();

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"); //ConcurrentModificationException并发修改异常

}

}

System.out.println(list);

###16.16_集合框架(jdk1.5静态导入的概述和使用)(掌握)
 A:静态导入概述
 B:格式:
     import static 包名….类名.方法名;
     可以直接导入到方法的级别
 C:注意事项
     方法必须是静态的,如果有多个同名的静态方法,容易不知道使用谁?这个时候要使用,必须加前缀。由此可见,意义不大,所以一般不用,但是要能看懂。

import static java.util.Arrays.sort; //静态导入

import static java.util.Arrays.toString; //静态导入

public class Demo2_StaticImport {

    public static void main(String[] args) {

int[] arr = {55,22,33,44,11};

sort(arr); //排序

//System.out.println(toString(arr));

}

}

###16.17_集合框架(jdk1.5可变参数的概述和使用)(掌握)
 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)泛型版的集合转数组

数组转换成集合

数组转换成集合虽然不能增加或减少元素,但是可以用集合的思想操作数组,也就是说可以使用其他集合中的方法。

    public static void demo2() {

//int[] arr = {11,22,33,44,55};

//List<int[]> list = Arrays.asList(arr); //基本数据类型的数组转换成集合,会将整个数组当作一个对象转换

//System.out.println(list); //[[I@67006d75]

Integer[] arr = {11,22,33,44,55}; //将数组转换成集合,数组必须是引用数据类型

List<Integer> list = Arrays.asList(arr);

System.out.println(list); //[11, 22, 33, 44, 55]

}

    public static void demo1() {

String[] arr = {"a","b","c"};

List<String> list = Arrays.asList(arr); //将数组转换成集合

//list.add("d");//ConcurrentModificationException //不能添加

System.out.println(list); //[a, b, c]

}

//集合转数组,加泛型的

ArrayList<String> list = new ArrayList<String>();

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.print(string + " "); //a b c d null null null null null null

}

###16.19_集合框架(集合嵌套之ArrayList嵌套ArrayList)(掌握)
 A:案例演示
     集合嵌套之ArrayList嵌套ArrayList

ArrayList<ArrayList<Person>> list = new ArrayList<ArrayList<Person>>();

ArrayList<Person> first = new ArrayList<Person>(); //创建第一个班级

first.add(new Person("杨幂", 30));

first.add(new Person("李冰冰", 33));

first.add(new Person("范冰冰", 20));

ArrayList<Person> second = new ArrayList<Person>();

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);

}

}

###16.20_day16总结
 把今天的知识点总结一遍。

###16.21_day16作业

1,定义一个方法swap()传入集合和两个角标使集合中元素交换位置

a,定义一个临时变量, 记住其中一个元素

b,用第一个位置存放第二个位置上的元素

c, 用第二个位置存放临时变量记住的元素

2,把集合中存储多个Person对象,Person有姓名和年龄,找出年龄最大的

a,定义一个Person类型的变量, 先记住第一个元素

b,循环遍历集合

c,用每一个元素和变量比较年龄, 如果集合中的元素比变量记住的年龄大

d,用变量记住这个年龄较大的元素

e,返回变量记住的元素

3,把集合中的元素反转

a,定义循环, 循环size()/2次

b,第一次交换第一个和最后一个, 第二次交换第二个和倒数第二个

4,public static void main(String[] args) {

List<String> list1 = new ArrayList<>();

list1.add("b");

list1.add("f");

list1.add("e");

list1.add("c");

list1.add("a");

list1.add("d");

sort1(list1);

System.out.println(list1); // a, b, c, d, e, f

List<Integer> list2 = new ArrayList<>();

list2.add(5);

list2.add(8);

list2.add(3);

list2.add(1);

list2.add(4);

sort2(list2);

System.out.println(list2); //1,3,4,5,8

}

对集合中添加的元素排序

5,List<String> list = new ArrayList<>();

list.add("a");

list.add("a");

list.add("a");

list.add("b");

list.add("b");

list.add("c");

list.add("d");

list.add("d");

list.add("d");

list.add("d");

list.add("d");

System.out.println(frequency(list, "a")); // 3

System.out.println(frequency(list, "b")); // 2

System.out.println(frequency(list, "c")); // 1

System.out.println(frequency(list, "d")); // 5

System.out.println(frequency(list, "xxx")); // 0

定义方法统计集合中指定元素出现的次数

6,定义一个replaceAll方法,将传入的新值替换集合中的老值(list,old,new)