java 深入技术三(List)
List
ArrayList
List接口
List接口的父接口-Collection
List接口的重要子类- ArrayList
-LikedList
List接口不重要子类-Vector
java.lang.IndexOutOfBoundsException 越界异常
1)ArrayList arrayList=new ArrayList();
//获取集合中的元素
Object element=arrayList.get(Index);
使用for循环获取集合中的所有元素
int size=arrayList.size();
for(int i=0;i<size;i++){
Object ele =arrayList.get(i);
System.out.println(ele);
}
2)ArrayList 内部数据结构:数组
内存地址 e0 e1 e2 e3 e4
10
类当中封装了一个数组,内存中位置是连续的,数组每个元素占的空间都是一样的
内部结构数组的特点决定了ArrayList的特点
*可以直接获取指定索引位置的元素arrayList.get(index)
*可以直接在指定位置添加元素 arrayList.add(1,"蛋蛋3");
*可以直接在指定索引位置删除元素 arrayList.remove(index);
获取元素效率:非常高
添加元素效率:非常低
删除元素效率:非常低
3)LinkedList
内部结构:链表
链首
LinkedList各种操作的效率分析
获取集合中元素,是从链首依次获取才能获取到
可以添加指定索引位置添加元素
可以删除指定索引位置的元素
添加效率:不需要移动元素
删除效率:不需要移动元素
查询效率:获取指定位置的元素:从链首依次计数到指定位置的元素,相对ArrayList慢一些
//Collection接口中没有的方法
linkedList.add();
linkedList.add(index,Object);
linkedList.get(Index);
linkedList.addFirst(Objcet);
linkedList.addLast(Objcet);
最大索引位置:linkedList.size()-1
4)LinkedList 添加元素的过程
LinkedList list =new LinkedList();
Person p=new Person("蛋蛋",20);
list.add(p);
Person p2=new Person("蛋蛋2",30);
list.add(p2);
5)List综述
LIst列表的特性
元素有序:元素的添加顺序和遍历顺序相同
元素可重复:同一个元素可以多次添加到(List)集合里面
这两个特性实际上是子类ArrayList和LinkedList所具有的
可以是否多次添加null呢?可以
List中只能添加对象,不能添加基本数据类型
如果添加了基本数据类型,是装箱了
List接口特有的方法
ArrayList和LinkedList的共有方法决定List接口可以有的方法
void add (int index,Object o)
void addAll()
Objcet get()
Object set() //修改特定索引位置的元素
int indexOf()查询指定位置是否有改元素
int lastIndexOf()//查询元素最后一次出现的位置
6)ListIterator---list专有的迭代器
boolean hasNext()
Objcet next()
int nextIndex() //下一个元素的索引
boolean hasPrevious() //判断是否有前一个元素
Object previous() //取出前一个元素,并把指针移动到前一个元素
int previousIndex()
void add(Object o) //添加一个元素
void remove()
void set(Object o)//修改指针指向的当前元素
7)Vector
内部数据结构:数组
Vector是线程安全的,在早起的jdk版本中已经有了,自己担负了ArrayList和LinkedList两个类的作用,但各个操作的性能很低
Vector内部的数组满时,新数组长度增长100%
8)list练习
1.去除集合中的元素
新建一个集合list2.遍历list中的元素,如果list2有,就不添加,如果没有就添加进去
2.一个集合中存储有各种类型的数据,现要求把所有字符串类型的元素,串联成一个字符串,对所有数值类型的元素求和,对所有Person类型的元素年龄求和已经统计人数,如果是其他类型的元素,就输出到控制台
1.判断element为字符串类型的 element instanceof String ,使用StringBuild,把字符串串联在一次StringBuild stringBuild=new StringBuild();stringBuild.append(element);
2.判断element为数值类型 element instanceof Number ,然后把数值类型的转换为字符串类型的,再把字符串类型的转换为Double类型的
String numberStr=String.valueof(element);
Double doublevalueof=Double.parseDouble(numberStr);
totalNumer=+doublevalueof;
3.判断element为Person类型,统计人数
Person person=(Person)element;
int age=Person.getAge();
totalAge+=age;
personcount++;
9)堆栈(stack)
特点:先进后出
10)队列(queue)
特点:先进先出
java 深入技术三(List)的更多相关文章
- Java进阶(三)多线程开发关键技术
原创文章,同步发自作者个人博客,转载请务必以超链接形式在文章开头处注明出处http://www.jasongj.com/java/multi_thread/. sleep和wait到底什么区别 其实这 ...
- Java基础扫盲系列(三)— Java内省技术
前言 Java内省技术属于Java基础体系的的一部分,但是很多人都不甚了解.笔者也是在学习Spring源码的过程中遇到该技术模块的.为了完善技术体系,本文将全面的学习该技术.在提到Java内省技术,就 ...
- java 深入技术八(内省)
1. javabean的软件设计思想 2.内省:封装了java反射,提供直接操作属性的Setter和getter方法的方法 3.核心API:BeanInfo java 的描述信息,Introspect ...
- 深入分析Java Web技术内幕(修订版)
阿里巴巴集团技术丛书 深入分析Java Web技术内幕(修订版)(阿里巴巴集团技术丛书.技术大牛范禹.玉伯.毕玄联合力荐!大型互联网公司开发应用实践!) 许令波 著 ISBN 978-7-121- ...
- Java加密技术(一)——BASE64与单向加密算法MD5&SHA&MAC
Java加密技术(一)——BASE64与单向加密算法MD5&SHA&MAC 博客分类: Java/Security Javabase64macmd5sha 加密解密,曾经是我一 ...
- Java Web技术总结(目录)
来源于:http://www.jianshu.com/p/539bdb7d6cfa Java Web技术经验总结(一) Java Web技术经验总结(二) Java Web技术经验总结(三) Java ...
- Java单元测试技术1
另外两篇关于介绍easemock的文章:EasyMock 使用方法与原理剖析,使用 EasyMock 更轻松地进行测试 摘要:本文针对当前业软开发现状,先分析了WEB开发的技术特点和单元测试要解决的问 ...
- Java加密技术
相关链接: Java加密技术(一)——BASE64与单向加密算法MD5&SHA&MAC Java加密技术(二)——对称加密DES&AES Java加密技术(三)——PBE算法 ...
- Java Servlet 技术简介
Java Servlet 技术简介 Java 开发人员兼培训师 Roy Miller 将我们现有的 servlet 介绍资料修改成了这篇易于学习的实用教程.Roy 将介绍并解释 servlet 是什么 ...
随机推荐
- js jQuery取消添加超链接的方法小结
今天在工作中需要将某个链接给取消实现只触发事件的目的,后来发现批量取消链接等,脚本之家简单的给整理了下,希望对需要的朋友有所帮助. 单个链接取消链接并触发js事件 <a href="j ...
- Vmware虚拟机配置LVS/NAT模式遇到的坑。
这两天在研究LVS的负载均衡,先从最简单的LVS/NAT模式开始入手. 最后配置完之后能够相互之间Ping通,并且能够直接访问real服务器提供的web服务,而且防火墙也已经关闭了. 但是通过访问LV ...
- learn mips
可以使用MARS来编汇编,MARS是一个用java编的IDE,它是一个模拟环境. 样例:重要的句子输出三遍 .data str: .asciiz "weidiao is great\n&qu ...
- qq菜单的折叠与展示
敲出每个小例子是一种进步 html结构: <body> <ul id="list"> <li class="lis"> &l ...
- hdu3415 单调队列
Max Sum of Max-K-sub-sequence Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & ...
- bzoj4591 【Shoi2015】超能粒子炮·改
由Lucas定理C(n,k)=C(n/2333,k/2333)*C(n%2333,k%2333)%2333 则ans=ΣC(n,i),(i<=k) =C(n/2333,0)*C(n%2333, ...
- js之 matches (可以取代jq的 delegate 方法)
问题:请给#wrap 下面的子元素添加点击事件! <div id="wrap"> <a class="btn" href="http ...
- RabbitMQ headers Exchange
Headers Exchange headers也是一种交换机类型,但是在rabbitmq官网中的教程中并没有说到.资料也很少,但是找一找总会有的. headers与direct的模式不同,不是使用r ...
- python模块(六)
模块,用一砣代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合.而对于一个复杂的功能来,可能需要多个函数才 ...
- LogStash配置、使用(三)
LogStash配置 官方文档:https://www.elastic.co/guide/en/logstash/current/index.html 查看yum安装路径 rpm -ql logsta ...