Java集合框架(二)day_16

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

public class Demo1_ArrayList {

    /**
     * * 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("c");
        list.add("c");
        list.add("c");
        list.add("c");

        ArrayList newList = getSingle(list);
        System.out.println(newList);
    }

    /*
     * 创建新集合将重复元素去掉
     * 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.集合框架(去除ArrayList中重复自定义对象元素)(掌握)
* A:案例演示
    * 需求:ArrayList去除集合中自定义对象元素的重复值(对象的成员变量值相同)
* B:注意事项
    * 重写equals()方法的
public class Demo2_ArrayList {

    /**
     * * A:案例演示
            * 需求:ArrayList去除集合中自定义对象元素的重复值(对象的成员变量值相同)
        * B:注意事项
            * 重写equals()方法的
        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));
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);
}

/*
 * 创建新集合将重复元素去掉
 * 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;
}
}
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(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + "]";
}
/*@Override
public boolean equals(Object obj) {
Person p = (Person)obj;
return this.name.equals(p.name) && this.age == p.age;
}*/

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

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

###16集合框架(用LinkedList模拟栈数据结构的集合并测试)(掌握)
* A:案例演示
    * 需求:请用LinkedList模拟栈数据结构的集合,并测试
    * 创建一个类将Linked中的方法封装
    *
            public class Stack {
                private LinkedList list = new LinkedList();     //创建LinkedList对象

                public void in(Object obj) {
                    list.addLast(obj);                          //封装addLast()方法
                }

                public Object out() {
                    return list.removeLast();                   //封装removeLast()方法
                }

                public boolean isEmpty() {
                    return list.isEmpty();                      //封装isEmpty()方法
                }
            }

16.集合框架(泛型概述和基本使用)(掌握)

public class Demo1_Generic {

    /**
        * 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,没有意义
        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());//next方法只能调用一次,如果调用多次会将指针向后移动多次
            Person p = it.next();
            System.out.println(p.getName() + "..." + p.getAge());
        }
    }

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

*public class Demo2_Generic {

    /**
     * * A:案例演示
     * ArrayList存储字符串并遍历泛型版
     */
    public static void main(String[] args) {
        //demo1();
        ArrayList<Person> list = new ArrayList<>();
        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<>();         //创建集合对象
        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_集合框架(泛型的由来)(了解)

public class Demo3_Generic {

    /**
     * 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 Demo4_Generic {

    /**

      • A:泛型接口概述

        • 把泛型定义在接口上
      • B:定义格式
        • public interface 接口名<泛型类型>
      • C:案例演示
        • 泛型接口的使用

          */

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

}*/

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

    @Override
    public void show(T t) {
        System.out.println(t);
    }

}

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

  • A:泛型方法概述

    • 把泛型定义在方法上
  • B:定义格式
    • public <泛型类型> 返回类型 方法名(泛型类型 变量名)
  • C:案例演示
    • 泛型方法的使用

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

  • A:泛型接口概述

    • 把泛型定义在接口上
  • B:定义格式
    • public interface 接口名<泛型类型>
  • C:案例演示
    • 泛型接口的使用
    • public class Demo4_Generic {

    /**

      • A:泛型接口概述

        • 把泛型定义在接口上
      • B:定义格式
        • public interface 接口名<泛型类型>
      • C:案例演示
        • 泛型接口的使用

          */

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

}*/

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

    @Override
    public void show(T t) {
        System.out.println(t);
    }

}

16.12_集合框架(泛型高级之通配符)(了解)

  • A:泛型通配符

16.13_集合框架(增强for的概述和使用)(掌握)

  • A:增强for概述

    • 简化数组和Collection集合的遍历
  • B:格式:
  • for(元素数据类型 变量 : 数组或者Collection集合) {

    使用变量即可,该变量就是元素

    }

  • C:案例演示
    • 数组,集合存储元素用增强for遍历
  • D:好处
    • 简化遍历

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 class Demo1_Foreach {

    /**
     * * A:增强for概述
            * 简化数组和Collection集合的遍历
        * B:格式:
        *
                for(元素数据类型 变量 : 数组或者Collection集合) {
                    使用变量即可,该变量就是元素
                }
        * C:案例演示
            * 数组,集合存储元素用增强for遍历
        * D:好处
            * 简化遍历
        增强for循环底层依赖的是迭代器(Iterator)
     */
    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);
    }

    public static void demo2() {
        ArrayList<Person> list = new ArrayList<>();
        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);
        }
    }

    public static void demo1() {
        int[] arr = {11,22,33,44,55};
        for (int i : arr) {
            System.out.println(i);
        }

        ArrayList<String> list = new ArrayList<>();
        list.add("a");
        list.add("b");
        list.add("c");
        list.add("d");

        for (String string : list) {
            System.out.println(string);
        }
    }

}

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

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

      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.集合框架(可变参数的概述和使用)(掌握)

  • 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.集合框架(Arrays工具类的asList()方法的使用)(掌握)

  • A:案例演示

    • Arrays工具类的asList()方法的使用
    • Collection中toArray(T[] a)泛型版的集合转数组
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);
    }

}
时间: 2024-10-03 14:02:17

Java集合框架(二)day_16的相关文章

Java集合框架(二)

Set Set:无序,不可以重复元素. |--------HashSet:数据结构是哈希表. 线程是非同步的.保证元素唯一性的原理是:判断元素的hashCode值是否相同,如果相同,还会继续判断元素的equals方法,是否为true |--------TreeSet:可以对Set集合中元素进行排序.  底层数据结构是二叉树(也叫红黑树),保证元素唯一性的依据是:compareTo()方法return 0. TreeSet排序的第一种方式:让元素自身具备比较性.元素需要实现Comparable接口

java 集合框架二(list)

/* Collection: |--List:集合中的元素是有序的,可重复的,有索引. |--Set:集合中的元素是无序的,不可重复的,无索引. List中的特有方法: 增 add(index,element); addAll(index,Collection); 删 remove(index); 改 set(index,element); 查 get(index); subList(start,end); listIterator(); 其他: indexOf(obj);//通过indexOf

(二)java集合框架综述

一集合框架图 说明:对于以上的框架图有如下几点说明 1.所有集合类都位于java.util包下.Java的集合类主要由两个接口派生而出:Collection和Map,Collection和Map是Java集合框架的根接口,这两个接口又包含了一些子接口或实现类.2. 集合接口:6个接口(短虚线表示),表示不同集合类型,是集合框架的基础.3. 抽象类:5个抽象类(长虚线表示),对集合接口的部分实现.可扩展为自定义集合类.4. 实现类:8个实现类(实线表示),对接口的具体实现.5. Collectio

jdk源码阅读笔记之java集合框架(二)(ArrayList)

关于ArrayList的分析,会从且仅从其添加(add)与删除(remove)方法入手. ArrayList类定义: p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Monaco } span.s1 { color: #931a68 } public class ArrayList<E> extends AbstractList<E> implements List<E> ArrayList基本属性: /** *

我所理解Java集合框架的部分的使用(Collection和Map)

所谓集合,就是和数组类似--一组数据.java中提供了一些处理集合数据的类和接口,以供我们使用. 由于数组的长度固定,处理不定数量的数据比较麻烦,于是就有了集合. 以下是java集合框架(短虚线表示接口,长虚线表示抽象类,实线表示类,箭头表示实现接口或者继承)(在网络上找的图,不知道原作者,侵权请联系我删除)(总之,关系很复杂,所以不用记得这个图,只是用来吓吓人而已的). 下面贴上个人理解之精简版之Collection(集)和Map(地图?暂且这么理解吧),话说思维导图蛮好用,以下是两幅思维导图

Java集合框架的知识总结

说明:面试准备,写的挺不错的. 转载地址: http://www.cnblogs.com/zhxxcq/archive/2012/03/11/2389611.html 1.综述 所有集合类都位于java.util包下.集合中只能保存对象(保存对象的引用变量).(数组既可以保存基本类型的数据也可以保存对象). 当我们把一个对象放入集合中后,系统会把所有集合元素都当成Object类的实例进行处理.从JDK1.5以后,这种状态得到了改进:可以使用泛型来限制集合里元素的类型,并让集合记住所有集合元素的类

Java集合框架(一)

Java集合框架结构图完整版 在完整版的结构图中Collection集合和Map下有许多未实现的抽象类(AbstractCollection.AbstractMap等等).下面整理一个简化版的,去除了一些不常用的子类和中间的一些抽象类. Java集合框架结构图简化版 说集合之前先来讲讲对象数组: 对象数组: 数组可以储存基本类型和引用类型,储存引用类型的数组叫对象数组(案例:用数组储存10个Animal类对象) 集合(Collection): a)集合的由来: Java语言是面对对象语言,需要操

Java集合框架实现自定义排序

Java集合框架针对不同的数据结构提供了多种排序的方法,虽然很多时候我们可以自己实现排序,比如数组等,但是灵活的使用JDK提供的排序方法,可以提高开发效率,而且通常JDK的实现要比自己造的轮子性能更优化. 一 .使用Arrays对数组进行排序 Java API对Arrays类的说明是:此类包含用来操作数组(比如排序和搜索)的各种方法. 1.使用Arrays排序:Arrays使用非常简单,直接调用sort()即可 int[] arr = new int[] {5,8,-2,0,10}; Array

java集合框架小结(进阶版)之HashMap篇

基本概念: Hash(哈希):hash一般也译作“散列”.事实上,就是一个函数,用于直接定址.将数据元素的关键字key作为变量,通过哈希函数,计算生成该元素的存储地址. 冲突:函数是可以多对一的.即:多个自变量可以映射到同一函数值.一般而言,不同的key的hash值是不同的.在往hash表中映射的时候,不同的hash值可能映射到同一存储地址,这种情况被称为冲突. 解决冲突的方法: 1. 链表法:将冲突的各个元素用一个一维数组来维护.(java源码实现) 2. 开发寻址法:具体的有线性探测法.二次

Java - 集合框架完全解析

来自:http://www.jianshu.com/p/63e76826e852 数据结构是以某种形式将数据组织在一起的集合,它不仅存储数据,还支持访问和处理数据的操作.Java提供了几个能有效地组织和操作数据的数据结构,这些数据结构通常称为Java集合框架.在平常的学习开发中,灵活熟练地使用这些集合框架,可以很明显地提高我们的开发效率,当然仅仅会用还是不够的,理解其中的设计思想与原理才能更好地提高我们的开发水平.下面是自己对Java集合框架方面的学习总结. 一.概述 二.Collection接