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 al = new ArrayList();
// 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
{
System.out.println("al("+x+")="+al.get(x));
}
// 迭代器
Iterator it = al.iterator();
while (it.hasNext())
{
sop("next: "+it.next());
}
// 通过 indexof 获取对象的位置
sop("indexof = "+al.indexOf("Java10"));
List sub = al.subList(0, 2);
sop("sub = "+sub);
}
public static void main(String[] args)
{
// TODO Auto-generated method stub
// 演示列表迭代器
ArrayList alArrayList = new ArrayList();
alArrayList.add("Java01");
alArrayList.add("Java02");
alArrayList.add("Java03");
sop(alArrayList);
// 使用 ListIterator 接口
ListIterator 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 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 LinkedList特有方法程序小解 &;&; 使用LinkedList 模拟一个堆栈或者队列数据结构。
package Collection; import java.util.LinkedList; /* LinkedList:特有的方法 addFirst()/addLast(); getFirst( ...
java.util 集合框架集合
java的集合框架为程序提供了一种处理对象组的标准方式.设计了一系列标准泛型接口: ⑴Collection ()接口,扩展了Iterable接口,位于集合层次结构的顶部,因此所有的集合都实现Colle ...
Java.io.ObjectOutputStream.writeObject()方法实例
java.io.ObjectOutputStream.writeObject(Object obj) 方法将指定对象写入ObjectOutputStream.该对象的类,类的签名,以及类及其所有超类型 ...
java中集合格式及json格式的特点和转换
作者原创:转载请注明出处 今天在写代码,遇到一个难点,由于要调用webservice接口,返回的为一个list集合内容,从webservice调用接口返回的为一个string的io流, 在调用接口的地 ...
java集合_collection子接口 list的特有方法,ArrayList类体现
/* Collection |--List:元素是有序的,元素可以重复.因为该集合体系有索引. |--ArrayList:底层的数据结构使用的是数组结构.特点:查询速度很快.但是增删稍慢.线程不同步. ...
java 15 -7 ListIterator 的特有方法
列表迭代器: ListIterator listIterator():List集合特有的迭代器 该迭代器继承了Iterator迭代器,所以,就可以直接使用hasNext()和next()方法. 特有 ...
《Java虚拟机原理图解》1.5、 class文件中的方法表集合--method方法在class文件中是怎样组织的
0. 前言 了解JVM虚拟机原理是每一个Java程序员修炼的必经之路.但是由于JVM虚拟机中有很多的东西讲述的比较宽泛,在当前接触到的关于JVM虚拟机原理的教程或者博客中,绝大部分都是充斥的文字性的描 ...
Java进阶(二十四)Java List集合add与set方法原理简介
Java List集合add与set方法原理简介 add方法 add方法用于向集合列表中添加对象. 语法1 用于在列表的尾部插入指定元素.如果List集合对象由于调用add方法而发生更改,则返回 tr ...
Java遍历集合的几种方法分析(实现原理、算法性能、适用场合)
概述 Java语言中,提供了一套数据集合框架,其中定义了一些诸如List.Set等抽象数据类型,每个抽象数据类型的各个具体实现,底层又采用了不同的实现方式,比如ArrayList和LinkedList ...
随机推荐
python导入opencv解决no module named cv2问题
最近ubuntu用的比较多,在写神经网络代码时也会经常接触到python,但是python的环境配置确实是个头疼的问题. 尤其是接触到opencv时,需要导入opencv的库文件,网上也有很多方法,本 ...
js从服务器下载文件
通常,将文件绝对路径url作为超链接的链接地址href的值,点击后,浏览器将会尝试请求文件资源,如果浏览器能够辨认文件类型,则将会以预设的打开方式直接打开下载的文件 ...
(转)textarea去掉右侧滚动条,去掉右下角拖拽
本文转载自:http://blog.csdn.net/cctv_end/article/details/7946188 代码: