package Collection;

/*
Collection
|--List:元素是有序的,元素可以重复。因为该集合体系有索引
| |--ArrayList:底层的数据结构使用的是数组结构 特点:查询,修改速度很快,但是增删稍慢。线程不同步
| |--LinkedList:底层使用的是链表的数据结构 特点:增删速度很快,查询稍慢
| |--Vector:底层是数组数据结构。线程同步。被ArrayList替代了
|--set:元素是无序,元素可以重复 List:集合特有的方法,凡是可以操作角标的方法都是该体系特有的方法 增
add(index,element);
addall(index,Collection); 删
remove(index); 改
set(index,element); 查
get(index);
subList(from , to);
listIterator(); List 集合特有的迭代器。ListIterator是Iterator的子接口
在迭代时,不可以通过集合对象的方法操作集合中的元素。因为会发生 Concurrent~~~ 异常。
所以,在迭代时,只能用迭代器的方法操作元素,可是 Iterator 方法是有限的,只能对元素
进行判断,取出,删除的操作。
如果想要其他的操作如添加,修改等,就要使用其子接口,Listiterator.
该接口只能通过List集合的listIterator方法获取。 */ import java.util.*; public class ListDemo
{ /**
* @param args
*/ public static void sop(Object obj)
{
System.out.println(obj);
} public static void method()
{
ArrayList<String> al = new ArrayList<String>(); // add
al.add("java01");
al.add("java02");
al.add("java03"); sop("原集合:"+al);
// 在指定位置添加元素
al.add(1,"java09"); // 删除指定元素
al.remove(2); // 修改元素
al.set(0, "Java10"); // 通过角标获取元素
sop("get(1):"+al.get(0));
sop(al); // 获取所有元素 for循环
for(int x = 0;x<al.size();x++)
{
System.out.println("al("+x+")="+al.get(x));
} // 迭代器
Iterator<String> it = al.iterator();
while (it.hasNext())
{
sop("next: "+it.next());
} // 通过 indexof 获取对象的位置
sop("indexof = "+al.indexOf("Java10"));
List<String> sub = al.subList(0, 2);
sop("sub = "+sub);
} public static void main(String[] args)
{
// TODO Auto-generated method stub // 演示列表迭代器
ArrayList<String> alArrayList = new ArrayList<String>();
alArrayList.add("Java01");
alArrayList.add("Java02");
alArrayList.add("Java03"); sop(alArrayList); // 使用 ListIterator 接口
ListIterator<String> li = alArrayList.listIterator(); // 有没有前一个元素
// sop("hasPrevious()"+li.hasPrevious());
while (li.hasNext())
{
Object obj = li.next();
if(obj.equals("Java01"))
{
// 添加
// li.add("Java11"); // 修改
li.set("Java11");
}
} while (li.hasPrevious())
{
sop("Pre::"+li.previous());
} // 有没有后一个元素
// sop("hasNext():"+li.hasNext());
// sop("hasPrevious()"+li.hasPrevious()); sop(alArrayList);
/*
* 使用 Iterator 接口
// 在迭代过程中,准备添加或者删除元素
Iterator<String> iterator = alArrayList.iterator();
while (iterator.hasNext())
{
// sop("next: "+iterator.next());
Object obj = iterator.next();
if (obj.equals("Java01"))
{
// alArrayList.add("Java11");
// 将 Java01 的引用从集合中删除了
iterator.remove();
}
sop("Obj = "+obj);
}
*/
}
}

  

Java List集合特有方法程序用法的更多相关文章

  1. Java LinkedList特有方法程序小解 && 使用LinkedList 模拟一个堆栈或者队列数据结构。

    package Collection; import java.util.LinkedList; /* LinkedList:特有的方法 addFirst()/addLast(); getFirst( ...

  2. Java中有关clone方法的用法

    一.clone在数组基本数据类型中的使用 public class Main { public static void main(String[] args) { int[] arr= {7,8,9} ...

  3. java.util 集合框架集合

    java的集合框架为程序提供了一种处理对象组的标准方式.设计了一系列标准泛型接口: ⑴Collection ()接口,扩展了Iterable接口,位于集合层次结构的顶部,因此所有的集合都实现Colle ...

  4. Java.io.ObjectOutputStream.writeObject()方法实例

    java.io.ObjectOutputStream.writeObject(Object obj) 方法将指定对象写入ObjectOutputStream.该对象的类,类的签名,以及类及其所有超类型 ...

  5. java中集合格式及json格式的特点和转换

    作者原创:转载请注明出处 今天在写代码,遇到一个难点,由于要调用webservice接口,返回的为一个list集合内容,从webservice调用接口返回的为一个string的io流, 在调用接口的地 ...

  6. java集合_collection子接口 list的特有方法,ArrayList类体现

    /* Collection |--List:元素是有序的,元素可以重复.因为该集合体系有索引. |--ArrayList:底层的数据结构使用的是数组结构.特点:查询速度很快.但是增删稍慢.线程不同步. ...

  7. java 15 -7 ListIterator 的特有方法

    列表迭代器:  ListIterator listIterator():List集合特有的迭代器 该迭代器继承了Iterator迭代器,所以,就可以直接使用hasNext()和next()方法. 特有 ...

  8. 《Java虚拟机原理图解》1.5、 class文件中的方法表集合--method方法在class文件中是怎样组织的

    0. 前言 了解JVM虚拟机原理是每一个Java程序员修炼的必经之路.但是由于JVM虚拟机中有很多的东西讲述的比较宽泛,在当前接触到的关于JVM虚拟机原理的教程或者博客中,绝大部分都是充斥的文字性的描 ...

  9. Java进阶(二十四)Java List集合add与set方法原理简介

    Java List集合add与set方法原理简介 add方法 add方法用于向集合列表中添加对象. 语法1 用于在列表的尾部插入指定元素.如果List集合对象由于调用add方法而发生更改,则返回 tr ...

随机推荐

  1. S3C2440的SPI解析

    位串行数据的频率.如果只希望发送,则接收数据可以保持伪位(dummy).此外如果只希望接收,则需要发送伪位'1'数据 使用SPI主要需要以下寄存器 选择SPI模式,中断模式,查询模式等SCK选择,主从 ...

  2. javascript--正则表达式--更新中

    引用地址:http://www.iteye.com/topic/481228 和http://www.cnblogs.com/rubylouvre/archive/2010/03/09/1681222 ...

  3. bzoj2453

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2453 题目大意: (1)       若第一个字母为“M”,则紧接着有三个数字L.R.W.表 ...

  4. 大数据全栈式开发语言 – Python

    前段时间,ThoughtWorks在深圳举办一次社区活动上,有一个演讲主题叫做“Fullstack JavaScript”,是关于用JavaScript进行前端.服务器端,甚至数据库(MongoDB) ...

  5. centos 6.5中安装hadoop2.2

    1.配置集群机器之间ssh免密码登录 (1) ssh-keygen -t dsa -P '' -f ~/.ssh/id_dsa 将id_dsa.pub 公钥 加入授权的key中去 这条命令的功能是把公 ...

  6. volatile的理解和使用

    package thread; /** * Created by Administrator on 2017/1/15. */ public class Counter { public volati ...

  7. 【BZOJ 3926】【ZJOI 2015】诸神眷顾的幻想乡

    http://www.lydsy.com/JudgeOnline/problem.php?id=3926 广义后缀自动机的例题,感觉广义后缀自动机好恶心... 广义后缀自动机是对一个trie建立的后缀 ...

  8. open in browser

    Sublime Text 3 Build 3065 Preferences-Key Bindings User: 直接key binding:{ "keys": ["al ...

  9. Apriori算法原理总结

    Apriori算法是常用的用于挖掘出数据关联规则的算法,它用来找出数据值中频繁出现的数据集合,找出这些集合的模式有助于我们做一些决策.比如在常见的超市购物数据集,或者电商的网购数据集中,如果我们找到了 ...

  10. HTML5 & CSS3初学者指南(3) – HTML5新特性

    介绍 本文介绍了 HTML5 的一些新特性.主要包含以下几个方面: Web 存储 地理位置 拖放 服务器发送事件 Web存储 HTML5 Web 存储的设计与构想是一个更好的机制来存储客户端的网络数据 ...