### 概述
有序的collection(也称为序列) . 此接口的用户可以对列表中每个元素的掺入位置进行精确的控制 .用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表中的元素 .
### 特点
* 它是一个元素存取有序的集合。例如,存元素的顺序是11、22、33。那么集合中,元素的存储就是按照11、22、33的顺序完成的) .
* 它是一个带有索引的集合,通过索引就可以精确的操作集合中的元素(与数组的索引是一个道理) .
* 集合中可以有重复的元素,通过元素的equals方法,来比较是否为重复的元素。
### 常用子类
1. ArrayList集合,底层是数组结构.
2. LinkedList集合,底层是链表结构.
### 方法
#### add(index , element) 将元素插入到列表指定索引上.
索引的插入得按序插入 .
~~~
List<String> list = new ArrayList<String>();
list.add("abc");
list.add("cba");
list.add("123");
Iterator<String> it = list.iterator();
while(it.hasNext()){
System.out.println(it.next());
}
~~~
#### remove(index) 移除指定索引上的元素 ,返回E类型 ,其实就是返回被删除的元素 .
~~~
List<String> list = new ArrayList<String>();
list.add("abc");
list.add("123");
System.out.println(list.remove(1));
System.out.println(list);
~~~
结果
~~~
123
[abc]
~~~
#### set(index) 修改指定索引上的值 , 并返回修改之前的值
~~~
List<String> list = new ArrayList<String>();
list.add("abc");
list.add("123");
System.out.println(list.set(1,"cba"));
System.out.println(list);
~~~
结果
~~~
123
[abc, cba]
~~~
### 堆栈:
* 先进后出(即,存进去的元素,要在后它后面的元素依次取出后,才能取出该元素)。例如,子弹压进弹夹,先压进去的子弹在下面,后压进去的子弹在上面,当开枪时,先弹出上面的子弹,然后才能弹出下面的子弹。
* 栈的入口、出口的都是栈的顶端位置 .
* 压栈:就是存元素。即,把元素存储到栈的顶端位置,栈中已有元素依次向栈底方向移动一个位置。
* 弹栈:就是取元素。即,把栈的顶端位置元素取出,栈中已有元素依次向栈顶方向移动一个位置。
![](https://box.kancloud.cn/f4992677bb4eadf0a11bb6093304b84f_746x702.png)
### 队列:
* 先进先出(即,存进去的元素,要在后它前面的元素依次取出后,才能取出该元素)。例如,安检。排成一列,每个人依次检查,只有前面的人全部检查完毕后,才能排到当前的人进行检查。
* 队列的入口、出口各占一侧。例如,下图中的左侧为入口,右侧为出口。
![](https://box.kancloud.cn/32dfbce89604fa0e776940f682436d47_806x666.png)
### 数组
* 查找元素快:通过索引,可以快速访问指定位置的元素 .
* 增删元素慢 :
* 指定索引位置增加元素:需要创建一个新数组,将指定新元素存储在指定索引位置,再把原数组元素根据索引,复制到新数组对应索引的位置 .
* 指定索引位置删除元素:需要创建一个新数组,把原数组元素根据索引,复制到新数组对应索引的位置,原数组中指定索引位置元素不复制到新数组中 .
![](https://box.kancloud.cn/1b62b4bd1f4fc2c07593ddf9935b29e5_776x828.png)
### 链表:
* 多个节点之间,通过地址进行连接。例如,多个人手拉手,每个人使用自己的右手拉住下个人的左手,依次类推,这样多个人就连在一起了。
* 查找元素慢:想查找某个元素,需要通过连接的节点,依次向后查找指定元素 .
* 增删元素快:
* 增加元素:操作如左图,只需要修改连接下个元素的地址即可。
* 删除元素:操作如右图,只需要修改连接下个元素的地址即可。
![](https://box.kancloud.cn/e9c8246ca2e3518b05f4d6796c34aee3_842x630.png)
一般数组用的比较多,因为项目中80%的业务都是做查询,检索 .
- 环境
- Java基础
- 数据类型
- 基本类型
- 引用类型
- Array
- Class
- ArrayList
- 流程控制
- ASCII码表
- 面向对象
- 概述
- 变量
- this
- 修饰符
- 封装
- 继承
- final
- static
- 接口
- 接口
- 抽象类
- overload
- 接口和抽象类区别
- 案例
- 多态
- 构造方法
- super
- 匿名对象
- 内部类
- 静态导入
- 包的声明和访问
- 代码块
- 代理设计模式
- 静态代码块
- Object类
- lambda表达式
- 枚举
- 定义枚举
- 常用方法
- 枚举常量
- 异常
- 可变参数
- Properties
- 概述
- Properties和持久化有关的方法
- 反射
- 类加载器
- 概述
- Class类
- 获取构造方法并运行
- 获取成员变量并改值
- 获取成员方法并运行
- 反射泛型擦除
- 反射通过配置文件运行
- 常用 API
- Date类
- DateFormat类
- Calendar类
- Math类
- String类
- object类
- System类
- 正则表达式
- BigInteger类
- BigDecimal类
- Arrays工具类
- StringBuffer类
- 基本类型包装类
- 自动装箱和自动拆箱
- 框架集合
- collection接口
- 概述
- 接口方法
- 迭代器
- 迭代器并发异常
- 增强for循环
- 泛型
- hashCode和equals
- List接口
- 概述
- ArrayList
- LinkedList
- vector
- Set接口
- 概述
- 对象的哈希值
- HashSet
- LinkedHashSet
- 保证自定义元素的唯一性(重写)
- ArrayList和HashSet的contains原理
- Map接口
- 概述
- Map集合常用方法
- 迭代Map
- Map存储自定义类型
- HashMap
- LinkedHashMap
- Hashtable
- 嵌套Map遍历
- 方法的可变参数
- collections工具类
- 集合嵌套
- 集合特点总结
- Collection集合工具类
- Arrays工具类
- File类
- 概述
- 获取方法
- 创建和删除
- 判断方法
- 其他方法
- 文件过滤器
- IO流
- 字节流
- 概述
- 字节流
- 字节流复制文件
- 字节缓冲流
- 复制单级文件夹
- 使用字节流读取中文的乱码问题
- 字符编码表
- 方便程序员的IO流
- 转换流
- 概述
- OutputStreamWriter类
- InputStreamWriter类
- 转换流和其他子类的区别
- 序列化流
- 概述
- 序列化接口以及版本号问题
- transient
- 打印流
- 多线程
- 概述
- main线程介绍
- 开启线程方式一:Thread类
- 开启线程方式二:Runnable类
- 线程的执行原理
- 使用哪种方式好
- 使用匿名内部类创建线程
- 线程安全
- ThreadLocal
- 网络编程
- XML
- 概述
- 语法
- 元素标签
- 属性
- 转义字符
- CDATA区
- XML约束
- DTD约束
- 三种引入DTD的方式
- DTD语法
- Schema约束
- JDBC
- 概述
- JDBC原理
- JDBC查询操作
- JDBCUtils
- 预处理对象
- JDBC连接池
- 概述
- DBCP
- C3P0
- DBUtils操作
- ArrayHandler
- ArrayListHandler
- BeanHandler
- BeanListHandler
- ColumnListHandler
- MapHandler
- MapListHandler
- ScalarHandler
- 事务
- 事务概述
- 原生JDBC完成转账
- DBUtils完成转账
- 事务特性
- 三层思想
- 概述
- JavaWEB
- tomcat
- servlet
- 概述
- 映射servlet
- Servlet接口
- HttpServlet类
- load-on-startup
- servletContext
- ServletRequest
- ServletResponse
- Cooike&Session
- servlet三大域对象
- JSP
- 概述
- jsp内置对象
- 指令
- page
- include
- taglib
- JSP中的四个域对象
- jsp的一个动作标签
- EL表达式
- 概述
- 获取域中数据
- 执行运算
- el表达式中的内置对象
- jsti标签
- 概念
- jstl分类
- Filter过滤器
- 概述
- 生命周期
- url-pattern配置
- filter的chain过滤链
- filter-mapping子标签
- 全局统一错误页面
- filterConfig
- 自动登录实例
- 全局统一编码
- Listener监听器
- 概念
- 监听器分类
- 监听三个对象的创建和销毁
- 监听三个对象属性的变化
- 监听javabean在session中的状态变化
- 定时器
- 概念
- calendar日历
- 邮件
- 概述
- JSON
- 数据结构
- 堆栈结构
- 队列结构
- 数组结构
- 链表结构
- 基础加强
- 面试题:增强一个对象的方法有几种方式?
- 装饰者增强
- 动态代理
- 动态代理
- 动态代理细节
- 使用动态代理解决字符集编码
- 注解
- 概述
- 扩展的自定义注解
- 类加载器
- 全盘负责托管机制
- 开发模式
- 问题
- lambda
- 函数式编程思想概述
- String字符串