集合01_List
List集合总览
- 元素有序,可重复,可通过索引访问
- 增加了通过索引操作集合的方法,如:
- Object get(int index)
- Object remove(int index)
- void sort(Comparator c)
books.sort((o1, o2) -> ((String)o1).length() - ((String)o2).length()); - void replaceAll(UnaryOperator operator),根据operator指定的计算规则重新设置元素值
books.replaceAll(ele -> ((String)ele).length());
- 判断元素相等的标准是两个对象通过equals方法比较返回true
- List提供了listIterator方法返回ListIterator对象,比Iterator增加了add方法向集合中添加元素,还支持向前迭代
ArrayList类
- 底层数据结构是数组(同Vector),其封装了一个动态的,允许再分配的Object[]数组,不指定容量数组默认长度为10
- ArrayList线程不安全,Vector线程安全
- 重写分配数组大小
- void ensureCapacity(int minCapacity),增大长度不小于minCapacity
- void trimToSize(),调整数组长度为当前元素个数,减少占用的存储空间
- 核心要点如下:
- add方法执行步骤:
- 检查数组容量是否足够(默认先判断+1是否满足),足够则直接添加
- 不足够则尝试扩容到原来的1.5倍是否足够
int hugeCapacity = length + (length >> 1);,足够则扩容(Vector扩容一倍) - 仍不足够则直接扩容到需要的容量
if (hugeCapacity - n < 0) {hugeCapacity = n;} - 扩容后调用
System.arraycopy(this.elementData, n, this.elementData, n + 1, this.size - n);复制,其是使用c ++编写的native静态方法,在数据量较大时有优势
- remove方法执行步骤:
- 检查角标
- 调用arraycopy进行复制,使元素向左移动覆盖被删除元素
- 将数组末尾置为null,等待GC回收
- 由此可见,删除元素不改变空间容量,减少容量需手动调用trimToSize()方法;可存放null值。
- add方法执行步骤:
LinkedList类
- 底层数据结构是双向链表,方便向前遍历
- 线程不安全
- 其实现了Deque接口,可以作为双端队列使用
固定长度的List
- Arrays工具类的asList(Object ...a)方法可以把一个数组或者制定个数的对象转换成一个List集合,它是Arrays的内部类ArrayList的实例。
- Arrays.ArrayList是一个固定长度的List集合,程序只能访问它,不能修改它
对线性表的性能分析
- 数组以一块连续的内存保存元素,以数组作为底层实现的集合随机访问性能最好
- 以链表作为底层实现的集合在执行插入删除操作时有较好的性能,因为可能需要经常重新分配内部数组的大小,如LinkedList集合
- 因此,查询多用ArrayList,增删多用LinkedList。对于极端情况,ArrayList性能要比LinkedList好
- 遍历集合,如果是ArrayList应使用随机访问(get),对于LinkedList应使用迭代器(Iterator)
集合01_List的更多相关文章
- java基础集合经典训练题
第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...
- .Net多线程编程—并发集合
并发集合 1 为什么使用并发集合? 原因主要有以下几点: System.Collections和System.Collections.Generic名称空间中所提供的经典列表.集合和数组都不是线程安全 ...
- 一起学 Java(三) 集合框架、数据结构、泛型
一.Java 集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个 ...
- 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)
建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...
- java基础_集合List与Set接口
List接口继承了Collection的方法 当然也有自己特有的方法向指定位置添加元素 add(索引,添加的元素); 移除指定索引的元素 remove(索引) 修改指定索引的元素 set ...
- Java基础Collection集合
1.Collection是所有集合的父类,在JDK1.5之后又加入了Iterable超级类(可以不用了解) 2.学习集合从Collection开始,所有集合都继承了他的方法 集合结构如图:
- 轻量级“集合”迭代器-Generator
Generator是PHP 5.5加入的新语言特性.但是,它似乎并没有被很多PHP开发者广泛采用.因此,在我们了解PHP 7对Generator的改进之前,我们先通过一个简单却显而易见的例子来了解下G ...
- Asp.net MVC 传递数据 从前台到后台,包括单个对象,多个对象,集合
今天为大家分享下 Asp.net MVC 将数据从前台传递到后台的几种方式. 环境:VS2013,MVC5.0框架 1.基本数据类型 我们常见有传递 int, string, bool, double ...
- 这些.NET开源项目你知道吗?.NET平台开源文档与报表处理组件集合(三)
在前2篇文章这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧 和这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,大伙热情高涨.再次拿出自己的私货,在.NET平台 ...
随机推荐
- ASCII 码
http://baike.baidu.com/link?url=Y4crTsVq678Z8fr92DAGIrqVHoexVXsMc-WKBMVUKGDq4KbEOuhWbUQXuQEtnlom4yln ...
- codeforces 975C Valhalla Siege
题意: 有n个巫师站成一列,每个巫师有自己的血量. 一个人射箭攻击他们,每次造成若干点伤害,巫师按照给定的顺序承受伤害,如果伤害大了,那么死掉,伤害落到下一个巫师身上. 如果一轮攻击之后,所有的巫师都 ...
- ODBC数据库
ODBC数据源全称是开放数据库互连(Open Database Connectivity),在微软公司开放的数据库结构中的一部分,其实是一个应用程序的接口,主要用于提供数据库的编写应用程序的能力.
- xshell中出现的绿色背景的文件夹
这种文件夹表示权限为777的文件夹 可以使用chmod 777 fileName进行权限修改 如果需要将文件夹以及其子文件夹的权限全部置为777 chmod 777 -R directoryName/ ...
- android studio eclipse keymap theme 快捷键 主题风格设置
android studio eclipse keymap theme 快捷键 主题风格设置 将Android Studio的快捷键设置与eclipse一致,使用习惯的快捷键才顺手.Mac系统下:进入 ...
- Qt介绍1---QPA(Qt Platform Abstraction)
Qt是一个夸平台的库(一直宣称“Qt everywhere”),但是Qt底层不是夸平台的.比如:Qt中Gui部件的核心类QWidget,该类除了qwidget.h 和 qwidget.cpp两个原文件 ...
- python docopt模块详解
python docopt模块详解 docopt 本质上是在 Python 中引入了一种针对命令行参数的形式语言,在代码的最开头使用 """ ""&q ...
- scala语言中的case关键字在spark中的一个奇特使用
package com.spark.demo import com.spark.demo.util.SparkUtil import org.apache.spark.rdd.RDD import s ...
- multer中间件
1.Multer是node.js的一个中间件,用于处理multipart/form-data类型的表单数据,它主要用于上传文件.(Multer不会处理任何非multipart/form-data类型的 ...
- webform 使用富文本编辑器
<div class="form-group"> <label class="col-xs-2 control-label text-right&quo ...