Java中可变数组的原理就是不断的创建新的数组,将原数组加到新的数组中,下文对Java List用法做了详解。

  • List:元素是有序的(怎么存的就怎么取出来,顺序不会乱),元素可以重复(角标1上有个3,角标2上也可以有个3)因为该集合体系有索引
  • ArrayList:底层的数据结构使用的是数组结构(数组长度是可变的百分之五十延长)(特点是查询很快,但增删较慢)线程不同步
  • LinkedList:底层的数据结构是链表结构(特点是查询较慢,增删较快)
  • Vector:底层是数组数据结构 线程同步(数组长度是可变的百分之百延长)(无论查询还是增删都很慢,被ArrayList替代了)

List:特有的方法,凡是可以操作角标的方法都是该体系特有的方法

  1. boolean add(int index, E element)
  2. boolean addAll(index,Collection)
  1. public static void List_add(){
  2. ArrayList a1 = new ArrayList();
  3. a1.add("java");
  4. a1.add("php");//List集合中的元素可以重复
  5. a1.add(".net");
  6. System.out.println("原集合:"+a1);
  7. a1.add(1, "Flash");
  8. a1.add(0, "ps");
  9. System.out.println(a1);
  10.  
  11. ArrayList a2 = new ArrayList();
  12. a2.add("javascript");
  13. a2.add("3dMax");
  14. a2.add("IBM");
  15.  
  16. a1.addAll(0, a2);
  17. System.out.println(a1);
  18. }

删除指定位置的元素

  1. boolean remove(int index)
  1. public static void List_remove(){
  2. ArrayList a1 = new ArrayList();
  3. a1.add("javascript");
  4. a1.add("php");
  5. a1.add("flash");
  6. System.out.println("原集合:"+a1);
  7.  
  8. a1.remove(0);
  9. System.out.println(a1);
  10. }

修改指定角标的元素  set(int index, E element)  返回的是修改的那个元素

  1. public static void List_set() {
  2. ArrayList a1 = new ArrayList();
  3. a1.add("javascript");
  4. a1.add("php");
  5. a1.add(".net");
  6. System.out.println("原集合:"+a1);
  7.  
  8. a1.set(1, "falsh");
  9. System.out.println(a1);
  10. }

  1. get(int index) 返回列表中指定位置的元素
  2. subList(int fromIndex, int toIndex) 返回列表中指定的 fromIndex(包括 )和 toIndex(不包括)之间的部分元素。
  1. public static void List_get() {
  2. ArrayList a1 = new ArrayList();
  3. a1.add("java");
  4. a1.add("php");
  5. a1.add("flash");
  6.  
  7. System.out.println(a1.get(0));//获取指定角标的元素,有了该方法就可以遍历该集合中的所有元素
  8.  
  9. System.out.println(a1.subList(1, 3));//获取集合中某一部分的元素,包含头不包含尾
  10. }

List集合特有的迭代器:ListIterator(是Iterator的子接口)

注意:

在迭代时,是不可以通过集合对象的方法操作集合中的元素因为会发生ConcurrentModificationException异常(并发异常)所以,在迭代器时,只能用迭代器的方法造作元素因为Iterator方法是有限的所以只能对元素进行判断,取出,删除的操作如果想要其他的操作如添加,修改等,就需要使用其子接口,ListIterator 该接口只能通过List集合的listIterator方法获取

  1. public class ListIteratorDemo {
  2. public static void main(String[] args) {
  3. ArrayList a1 = new ArrayList();
  4. a1.add("java01");
  5. a1.add("java02");
  6. a1.add("java03");
  7. a1.add("java04");
  8.  
  9. System.out.println("原集合是:"+a1);
  10.  
  11. /*在迭代过程中准备添加或者删除元素
  12. Iterator it = al.iterator();
  13. while (it.hasNext()){
  14.   Object obj = it.next();
  15.  
  16.   if (obj.equals("java02"))
  17.   //al.add("java008");//会出现并发异常,因为迭代器正在操作集合,不能再用集合的方法操作集合了
  18.   it.remove();//将java02的引用从集合中删除了
  19.   System.out.println("obj:"+obj);
  20. }
  21. */
  22. //只有List的listIterator有增,删,改,查这些功能,因为只有List有索引
  23. ListIterator li = a1.listIterator();
  24. while (li.hasNext()){
  25. if(li.next().equals("java02"))
  26. //li.add("java009");
  27. li.set("java006");
  28. }
  29. }
  30. }

Vector:枚举就是Vector特有的取出方式,跟迭代器很像(其实枚举和迭代是一样的) 已经被迭代器取代

  1. public class VectorDemo {
  2. public static void main(String[] args) {
  3. Vector v = new Vector();
  4. v.add("java01");
  5. v.add("java02");
  6. v.add("java03");
  7. v.add("java04");
  8.  
  9. for(Enumeration en = v.elements();en.hasMoreElements();){
  10. System.out.println(en.nextElement());
  11. }
  12. }
  13. }

LinkedList:

特有方法:

addFirst();在头部添加元素

addLast();在尾部添加元素

getFirst(); getLast();

获取元素但不删除元素。如果集合中没有元素,会出现NoSuchElementException

removeFirst();   removeLast();

获取元素但是删除元素。如果集合中没有元素,会出现NoSuchElementException

在JDK1.6出现了替代方法

offerFirst(); offerLast();

peekFirst(); peekLast(); 获取元素,但是元素不被删除。如果集合中没有元素,会返回null

pollFirst(); pollLast(); 获取元素,但是元素被删除。如果集合中没有元素,会返回null

  1. public class LinkedListDemo {
  2. public static void main(String[] args) {
  3. LinkedList link = new LinkedList();
  4. link.add("java01");
  5. link.add("java02");
  6. link.add("java03");
  7. link.add("java04");
  8.  
  9. while(!link.isEmpty()){
  10. System.out.println((link.removeLast()));
  11. }
  12. }
  13. }

Java List 用法代码分析 非常详细的更多相关文章

  1. Linux内核2.6.14源码分析-双向循环链表代码分析(巨详细)

    Linux内核源码分析-链表代码分析 分析人:余旭 分析时间:2005年11月17日星期四 11:40:10 AM 雨 温度:10-11度 编号:1-4 类别:准备工作 Email:yuxu97101 ...

  2. Java反编译代码分析(一)

    浅析如何读懂这种反编译过来的文件,不喜勿喷. 赋值 Node node; Node node1 = _$3.getChildNodes().item(0); node1; node1; JVM INS ...

  3. 常用 Java 静态代码分析工具的分析与比较

    常用 Java 静态代码分析工具的分析与比较 简介: 本文首先介绍了静态代码分析的基 本概念及主要技术,随后分别介绍了现有 4 种主流 Java 静态代码分析工具 (Checkstyle,FindBu ...

  4. [转载] 常用 Java 静态代码分析工具的分析与比较

    转载自http://www.oschina.net/question/129540_23043 简介: 本文首先介绍了静态代码分析的基本概念及主要技术,随后分别介绍了现有 4 种主流 Java 静态代 ...

  5. 【转载】常用 Java 静态代码分析工具的分析与比较

    摘自:http://www.oschina.net/question/129540_23043常用 Java 静态代码分析工具的分析与比较 简介: 本文首先介绍了静态代码分析的基本概念及主要技术,随后 ...

  6. 常用Java静态代码分析工具的分析与比较

    给国产静态代码检测工具Pinpoint打Call! 简介 本文首先介绍了静态代码分析的基本概念及主要技术,随后分别介绍了4种现有的主流Java静态代码分析工具 (Checkstyle,FindBugs ...

  7. java代码分析及分析工具

    一个项目从搭建开始,开发的初期往往思路比较清晰,代码也比较清晰.随着时间的推移,业务越来越复杂.代码也就面临着耦合,冗余,甚至杂乱,到最后谁都不敢碰. 作为一个互联网电子商务网站的业务支撑系统,业务复 ...

  8. 你真的了解java的lambda吗?- java lambda用法与源码分析

    你真的了解java的lambda吗?- java lambda用法与源码分析 转载请注明来源:cmlanche.com 用法 示例:最普遍的一个例子,执行一个线程 new Thread(() -> ...

  9. 完整全面的Java资源库(包括构建、操作、代码分析、编译器、数据库、社区等等)

    构建 这里搜集了用来构建应用程序的工具. Apache Maven:Maven使用声明进行构建并进行依赖管理,偏向于使用约定而不是配置进行构建.Maven优于Apache Ant.后者采用了一种过程化 ...

随机推荐

  1. POJ3697+BFS+hash存边

    /* 疾速优化+hash存边 题意:给定一个包含N(1 ≤ N ≤ 10,000)个顶点的无向完全图,图中的顶点从1到N依次标号.从这个图中去掉M(0 ≤ M ≤ 1,000,000)条边,求最后与顶 ...

  2. linux ubuntu 11.04 samba 服务器设置

    安装 SAMBA 组件 sudo apt-get install samba smbfs smbclient   配置相关参数 sudo gedit /etc/samba/smb.conf 文件中相关 ...

  3. BZOJ 4311 向量

    shallot+向量集 混合版? 首先我们考虑每个向量的存在时间为[L,R] 那么我们知道任意一个区间在线段树上最多被分解成logn个区间 那么我们可以像shallot一样进行区间覆盖 注意到本题的查 ...

  4. Nginx-location配置指南

    语法规则: location [=|~|~*|^~] /uri/ { … } = 开头表示精确匹配 ^~ 开头表示uri以某个常规字符串开头,理解为匹配 url路径即可.nginx不对url做编码,因 ...

  5. 从iPhone4、iPhone5、iPhone6看手机外壳加工工艺进化史

    从iPhone4.iPhone5到iPhone6,苹果为我们推出了一代又一代新产品,让我们享受到最新的科技产品.每次不只是配置上的改变,苹果在工艺上也不断改变.下面就阐述一下我对这几款手机在设计和制造 ...

  6. Qt之启动外部程序(调用cmd.exe ping putty winscp 管道等等,比较牛叉)

    http://blog.csdn.net/u011012932/article/details/50478833

  7. UVA548——Tree(中后序建树+DFS)

    Tree You are to determine the value of the leaf node in a given binary tree that is the terminal nod ...

  8. forks rate异常

    一.收到nagios Current_load报警短信

  9. Windows下Vim设置

    进入安装目录,找到_vimrc文件,用文本编辑器打开,在前面加入下述内容 设置中文支持 " 设置编码自动识别, 中文引号显示 " set fileencodings=utf-8,c ...

  10. bzoj1029

    贪心,比较明显了(很像USACO的风格); 按时间限制排序(升序) 顺次处理,如果当前时间能够修复就修复 否则就在之前修复的任务中找一个耗时最多(大于当前任务)的,改成修当前任务; 显然这样最优吧, ...