• 5.02_List集合


    一、去除ArrayList中重复字符串元素方式
      * A:案例演示
        * 需求: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("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; //将新集合返回
    }

    二、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模拟栈数据结构的集合并测试
      * 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()方法
        }
    }

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

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

    七、泛型类的概述及使用
      * A:泛型类概述<T>
        * 把泛型定义在类上
      * B:定义格式
        * public class 类名<泛型类型1,…>
        * C:注意事项
        * 泛型类型必须是引用类型
      * D:案例演示
        * 泛型类的使用

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

    九、泛型接口的概述和使用
      * A:泛型接口概述
        * 把泛型定义在接口上
      * B:定义格式
        * public interface 接口名<泛型类型>
      * C:案例演示
        * 泛型接口的使用

    十、泛型高级之通配符
      * A:泛型通配符<?>
        * 任意类型,如果没有明确,那么就是Object以及任意的Java类了
      * B:? extends E
        * 向下限定,E及其子类
      * C:? super E
        * 向上限定,E及其父类


    十一、增强for的概述和使用
      * A:增强for概述
        * 简化数组和Collection集合的遍历
      * B:格式:
      *
        for(元素数据类型 变量 : 数组或者Collection集合) {
        使用变量即可,该变量就是元素
        }
      * C:案例演示
        * 数组,集合存储元素用增强for遍历
      * D:好处
        * 简化遍历


    十二、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);
          }
    十三、三种迭代的能否删除
      * 普通for循环,可以删除,但是索引要--
      * 迭代器,可以删除,但是必须使用迭代器自身的remove方法,否则会出现并发修改异常
      * 增强for循环不能删除

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

    十五、可变参数的概述和使用
      * A:可变参数概述
        * 定义方法的时候不知道该定义多少个参数
      * B:格式
        * 修饰符 返回值类型 方法名(数据类型… 变量名){}
      * C:注意事项:
        * 这里的变量其实是一个数组
        * 如果一个方法有可变参数,并且有多个参数,那么,可变参数肯定是最后一个

  • 相关阅读:
    oracle12c之二 控制PDB中SGA 与 PGA 内存使用
    oracle12c之一 控制-PDB的磁盘I/O(IOPS,MBPS)资源管理
    DB link的迁移
    xtts v4for oracle 11g&12c(文档ID 2471245
    Xtts v4变化&先决条件&已知问题
    Xtts v4 xttdriver.pl & xtt.properties
    TT 安装之 Windwos
    TT 安装前配置 共享内存,在页,信号量
    TT 安装 之 AIX
    TimesTen LINUX 安装日志
  • 原文地址:https://www.cnblogs.com/zyyzy/p/12432457.html
Copyright © 2020-2023  润新知