List简介

  • List是有序、可重复的容器。
    有序:List中每个元素都有索引标记。可以根据元素的索引标记(在List中的位置)访问元素,从而精确控制这些元素。
    可重复:List允许加入重复的元素。更确切地讲,List通常允许满足 e1.equals(e2) 的元素重复加入容器。
  • 除了Collection接口中的方法,List多了一些跟顺序(索引)有关的方法.
  • List接口常用的实现类有3个:ArrayList、LinkedList和Vector.

初始化List

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

List接口中定义的方法

  • void add(int index, E element); 在指定位置插入元素,以前元素全部后移一位

    实例:

    一般add()添加元素

    1     list.add("A");
    2 list.add("B");
    3 list.add("D");
    4 list.add("E");

List的add添加

1     list.add(2, "C");
  • E set(int index, E element); 修改指定位置的元素
    实例:

    1     list.set(4,"H");
    2 System.out.println(list);
  • E get(int index); 返回指定位置的元素

    1     System.out.println(“输出元素:”+list.get(1));
  • E remove(int index); 删除指定位置的元素,后面元素全部前移一位
    实例:

    1      list.remove(2);
    2 System.out.println(list);
  • int indexOf(Object o);返回第一个匹配元素的索引,如果没有该元素,返回-1
    实战:

    1     // 从头到尾找到第一个"H"
    2 System.out.println(list.indexOf("H"));
  • int lastIndexOf(Object o);返回最后一个匹配元素的索引,如果没有该元素,返回-1
    实战:

    1     // 从尾到头找到第一个"H"
    2 System.out.println(list.lastIndexOf("H"));

List并集和交集处理

  • 创建实例的集合

    1     List<String> list1 = new ArrayList<String>();
    2 list1.add("张三");
    3 list1.add("李四");
    4 list1.add("王五");
    5
    6 List<String> list2 = new ArrayList<String>();
    7 list2.add("张三");
    8 list2.add("赵大");
    9 list2.add("钱二");
  • containsAll() 包含
    实例:

    1     //list1是否包含list2中所有元素
    2 System.out.println(list1.containsAll(list2));
  • addAll() 合并两个集合
    实例:

    1     //将list2中所有元素都添加到list1中
    2 list1.addAll(list2);
  • removeAll() 一个集合中去除另一个集合的内容
    实例:

    1     //从list1中删除同时在list和list2中存在的元素
    2 list1.removeAll(list2);
  • retainAll() 两个集合取交集
    实例:

    1    //取list1和list2的交集
    2 list1.retainAll(list2);

List常用方法

  • 创建实例的集合

    1     List<String> list = new ArrayList<>();
  • boolean isEmpty(); 容器是否为空

实例:

1      System.out.println(list.isEmpty());
  • boolean add(E e); 增加元素到容器中

实例:

1     list.add("张三");
2 list.add("李四");
3 System.out.println(list);
  • int size(); 容器中元素的数量

实例:

1     System.out.println("list的数量大小:" + list.size());
  • boolean contains(Object o); 容器中是否包含该元素

实例:

1     System.out.println("是否包含指定元素:" + list.contains("张三"));
  • boolean remove(Object o); 从容器中移除元素

实例:

1      list.remove("李四");
2 System.out.println(list);
  • Object[] toArray();转化成Object数组

实例:

1     Object[] objects = list.toArray();
2
3 System.out.println("转化成Object数组:" + Arrays.toString(objects));
  • void clear();清楚容器中所有元素

实例:

1     list.clear();
2
3 System.out.println("清空所有元素:" + list);

JDK源码阅读-------自学笔记(二十)(java.util.List初探)的更多相关文章

  1. JDK源码阅读-------自学笔记(二十五)(java.util.Vector 自定义讲解)

    Vector 向量 Vector简述 1).Vector底层是用数组实现的List 2).虽然线程安全,但是效率低,所以并不是安全就是好的 3).底层大量方法添加synchronized同步标记,sy ...

  2. JDK源码阅读-------自学笔记(二十四)(java.util.LinkedList 再探 自定义讲解)

    一.实现get方法 1.一般思维实现思路 1).将对象的值放入一个中间变量中. 2).遍历索引值,将中间量的下一个元素赋值给中间量. 3).返回中间量中的元素值. 4).示意图 get(2),传入角标 ...

  3. JDK源码阅读-------自学笔记(一)(java.lang.Object重写toString源码)

    一.前景提要 Object类中定义有public String toString()方法,其返回值是 String 类型. 二.默认返回组成 类名+@+16进制的hashcode,当使用打印方法打印的 ...

  4. JDK源码阅读-------自学笔记(五)(浅析数组)

    一.数组基础 1.定义和特点 数组也可以看做是对象,数组变量属于引用类型,数组中每个元素相当于该队形的成员变量,数组对象存储在堆中. 2.初始化数组 常用类初始化 // 整型初始化 int[] int ...

  5. 利用IDEA搭建JDK源码阅读环境

    利用IDEA搭建JDK源码阅读环境 首先新建一个java基础项目 基础目录 source 源码 test 测试源码和入口 准备JDK源码 下图框起来的路径就是jdk的储存位置 打开jdk目录,找到sr ...

  6. JDK源码阅读-ByteBuffer

    本文转载自JDK源码阅读-ByteBuffer 导语 Buffer是Java NIO中对于缓冲区的封装.在Java BIO中,所有的读写API,都是直接使用byte数组作为缓冲区的,简单直接.但是在J ...

  7. JDK源码阅读(三):ArraryList源码解析

    今天来看一下ArrayList的源码 目录 介绍 继承结构 属性 构造方法 add方法 remove方法 修改方法 获取元素 size()方法 isEmpty方法 clear方法 循环数组 1.介绍 ...

  8. JDK源码阅读(一):Object源码分析

    最近经过某大佬的建议准备阅读一下JDK的源码来提升一下自己 所以开始写JDK源码分析的文章 阅读JDK版本为1.8 目录 Object结构图 构造器 equals 方法 getClass 方法 has ...

  9. JDK源码阅读(1)_简介+ java.io

    1.简介 针对这一个版块,主要做一个java8的源码阅读笔记.会对一些在javaWeb中应用比较广泛的java包进行精读,附上注释.对于容易混淆的知识点给出相应的对比分析. 精读的源码顺序主要如下: ...

  10. ZooKeeper源码阅读——client(二)

    原创技术文章,转载请注明:转自http://newliferen.github.io/ 如何连接ZooKeeper集群   要想了解ZooKeeper客户端实现原理,首先需要关注一下客户端的使用方式, ...

随机推荐

  1. #差分,前缀和#nssl 1469 U

    分析 考虑离线,因为异或和很难在线处理 然后可以用两个数组来差分斜与横的情况,然后将答案竖着传 时间复杂度\(O(n^2)\) 代码 #include <cstdio> #include ...

  2. 面向OpenHarmony终端的密码安全关键技术

      本文转载自 OpenHarmony TSC 官方微信公众号<峰会回顾第17期 | 面向OpenHarmony终端的密码安全关键技术> 演讲嘉宾 | 何道敬 回顾整理 | 廖   涛 排 ...

  3. C++ 数学函数、头文件及布尔类型详解

    C++ 数学 C++ 有许多函数可以让您在数字上执行数学任务. 最大值和最小值 max(x, y) 函数可用于找到 x 和 y 的最大值: 示例 cout << max(5, 10); 而 ...

  4. C# PropertyChanged 事件-数据绑定

    在.NET平台上,数据绑定是一项令人十分愉快的技术.利用数据绑定能减少代码,简化控制逻辑. 通常,可以将某个对象的一个属性绑定到一个可视化的控件上,当属性值改变时,控件上的显示数据也随之发生变化.要实 ...

  5. Qt 实现涂鸦板三:实现鼠标绘制矩形

    .h 文件 #pragma once #include <QtWidgets/QWidget> #include "ui_xuexi.h" #include " ...

  6. Push failed idea将项目发布到gitHub失败

    此时需要点击VCS --> inport into version..-->create git ...重新生成仓库

  7. HarmonyOS应用性能与功耗云测试

    性能测试 性能测试主要验证HarmonyOS应用在华为真机设备上运行的性能问题,包括启动时长.界面显示.CPU占用和内存占用.具体性能测试项的详细说明请参考性能测试标准. 性能测试支持Phone和TV ...

  8. 动态规划(二)——背包dp

    01背包问题(每个物品最多选一次) AcWing 2. 0/1背包问题 朴素の版本: #include <bits/stdc++.h> using namespace std; const ...

  9. CSS 布局专题

    0x01 浮动布局 (1)常见网页布局 顶部商标栏(Logo):展示网站的标志.名称以及具有代表性的图片 导航栏(Navigation):展示网站大概的分类 左侧边栏(Left-side Bar):展 ...

  10. 报表输入页码翻页(润乾 V2018)

    报表数据分了太多页,一页一页翻页查看数据嫌麻烦,可以试试这种翻页效果--输入页码翻页. 润乾报表提供了翻页相关的 JS 函数,可以在报表展现的页面中添加 JS 调用翻页函数实现输入页码跳转到对应页. ...