一、List接口

List是Collection的子接口,里面可以保存各个重复的内容,此接口的定义如下:
public interface List<E> extends Collection<E>

二、List接口的扩展方法

No.
方法
类型
描述
1
public void add(int index, E element)
普通
在指定位置增加元素
2
public boolean addAll(int index, Collection<? extends E> c)
普通
在指定位置增加一组元素
3
E get(int index)
普通
返回指定位置的元素
4
public int indexOf(Object o)
普通
查找指定元素的位置
5
public int lastIndexOf(Object o)
普通
从后向前查找指定元素的位置
6
public ListIterator<E> listIterator()
普通
为ListIterator接口实例化
7
public E remove(int index)
普通
按指定的位置删除元素
8
public List<E> subList(int fromIndex, int toIndex)
普通
取出集合中的子集合
9
public E set(int index, E element)
普通
替换指定位置的元素

三、List接口的常用子类 —— ArrayList和LinkedList

ArrayList实现了长度可变的数组,在内存中分配连接的空间,遍历和随机访问元素的效率比较高
LinkedList采用链表存储方式。在插入、删除元素时效率比较高
 

四、ArrayList例子

package com.pb.demo1;

public class Person {
private String name;
private int age; public Person() { } public Person(String name, int age) {
this.name = name;
this.age = age;
} public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
package com.pb.demo1;

import java.util.ArrayList;
import java.util.List; public class PersonArrayListTest { public static void main(String[] args) {
/*
* 创建多个Person对象并赋值
*/
Person p1 = new Person("张三",21);
Person p2 = new Person("李四",22);
Person p3 = new Person("王五",23);
//创建ArrayList
List<Person> personlist=new ArrayList<Person>(); //为集合添加对象
personlist.add(p1);
personlist.add(p2);
personlist.add(p3);
//输出集合的长度
System.out.println("集合长度:"+personlist.size());
//遍历集合for循环
for(int i=0; i<personlist.size();i++){
System.out.println("姓名:"+personlist.get(i).getName()+"年龄:"+personlist.get(i).getAge());
} //使用索引添加
Person p4 = new Person("赵六",24);
/*
* 使用索引添加时必须知道长度才可以正确增加,如果添加的索引大于最后一个下标+1,
* 编译可以通过但运行时会报错
* 例如:如查长度为3,下标是从0开始到2,这时使用索引添加值索引可以是(0~3)都可以,但是不能是4
*/ personlist.add(0, p4);
//输出集合的长度
System.out.println("集合长度:"+personlist.size());
////遍历集合forearch循环
for (Person p : personlist) {
System.out.println("姓名:"+p.getName()+"年龄:"+p.getAge());
} //查找集合中是否有p4对象true代表有,false代表没有
System.out.println("查找集合中是否有p4对象:"+personlist.contains(p4));
//p2元素所在的下标从前向后
System.out.println("p2元素所在的下标从前向后:"+ personlist.indexOf(p2));
//p2元素所在的下标从后向前
System.out.println("p2元素所在的下标从后向前:"+ personlist.lastIndexOf(p2)); } }

五、LinkedList例子

package com.pb.demo1;

import java.util.LinkedList;
import java.util.List; public class PersonLinkedListTest { public static void main(String[] args) {
/*
* 创建多个Person对象并赋值
*/
Person p1 = new Person("张三",21);
Person p2 = new Person("李四",22);
Person p3 = new Person("王五",23);
Person p4 = new Person("赵六",24);
Person p5 = new Person("钱七",25); //创建LinkedList
LinkedList<Person>plist=new LinkedList<Person>();
plist.add(p1);
plist.add(p2);
plist.add(p3);
//集合长度
System.out.println("集合长度"+plist.size());
//遍历集合
for (Person p : plist) {
System.out.println("姓名:"+p.getName()+"年龄:"+p.getAge());
}
//在第一个和最后一个添加对象
plist.addFirst(p4);
plist.addLast(p5);
System.out.println("===========添加数据=================");
//集合长度
System.out.println("集合长度"+plist.size());
//遍历集合
for (Person p : plist) {
System.out.println("姓名:"+p.getName()+"年龄:"+p.getAge());
} //获取指定下标的元素:下标要已经存在如果不存在运行后将报错
System.out.println("获取指定下标的元素:"+plist.get(4).getName());
System.out.println("===========按下标移除=================");
//移除元素remove,按下标移除
plist.remove(0);
//集合长度
System.out.println("集合长度"+plist.size());
//遍历集合
for (Person p : plist) {
System.out.println("姓名:"+p.getName()+"年龄:"+p.getAge());
}
System.out.println("===========直接移除对象=================");
//移除元素remove 直接移除对象,
plist.remove(p2);
//集合长度
System.out.println("集合长度"+plist.size());
//遍历集合
for (Person p : plist) {
System.out.println("姓名:"+p.getName()+"年龄:"+p.getAge());
}
System.out.println("===========移除第一个或者最后一个=================");
//移除元素移除第一个或者最后一个
plist.removeFirst();
plist.removeLast();
//集合长度
System.out.println("集合长度"+plist.size());
//遍历集合
for (Person p : plist) {
System.out.println("姓名:"+p.getName()+"年龄:"+p.getAge());
}
System.out.println("===========移除全部=================");
//移除全部元素clear方法
plist.clear();
//集合长度
System.out.println("集合长度"+plist.size());
//遍历集合
for (Person p : plist) {
System.out.println("姓名:"+p.getName()+"年龄:"+p.getAge());
} } }

六、Vector类

在List接口中还有一个子类:Vector,Vector类属于一个挽救的子类,从整个JAVA的集合发展历史来看,Vector算是一个元老级的类,在JDK 1.0的时候就已经存在类此类。但是到了JAVA 2(JDK 1.2)之后重点强调了集合框架的概念,所以先后定义了很多的新接口(如:List等),但是考虑到一大部分的人已经习惯了使用Vector类,所以JAVA的设计者,就让Vector类多实现了一个List接口,这才将其保留下来。但是因为其是List子类,所以Vector类的使用与之前的并没有太大的区别。
package com.pb.demo1;

import java.util.Vector;

public class VectorTest {

    public static void main(String[] args) {

        Vector<String> plist=new Vector<String>();

        plist.add("张三");
plist.add("李四");
plist.add("王五");
plist.add("赵六");
System.out.println("长度:"+plist.size());
for (String s : plist) {
System.out.println(s);
} } }

Java从零开始学二十一(集合List接口)的更多相关文章

  1. Java从零开始学二十三(集合Map接口)

    一.Map接口 Collection.Set.List接口都属于单值的操作,即:每次只能操作一个对象,而Map与它们不同的是,每次操作的是一对对象,即二元偶对象,Map中的每个元素都使用key à v ...

  2. Java从零开始学二十(集合简介)

    一.为什么需要集合框架 数组的长度是固定的,但是如果写程序时并不知道程序运行时会需要多少对象.或者需要更复杂的方式存储对象,---那么,可以使用JAVA集合框架,来解决这类问题 二.集合框架主要接口 ...

  3. Java从零开始学二十二(集合Set接口)

    一.Set接口的定义 Set接口也是Collection接口的子接口,但是与Collection或List接口不同的是,Set接口中不能加入重复的元素 Set接口的主要方法与Collection是一致 ...

  4. Java从零开始学二十四(集合工具类Collections)

    一.Collections简介 在集合的应用开发中,集合的若干接口和若干个子类是最最常使用的,但是在JDK中提供了一种集合操作的工具类 —— Collections,可以直接通过此类方便的操作集合 二 ...

  5. Java从零开始学四十一(反射简述二)

    一.实例化Class类对象 实例化Class类对象的方法有三种: 第一种:通过forName()方法 第二种:类.class 第三种:对象.getClass() 二.Class类的常用方法 No. 方 ...

  6. Java从零开始学十八(抽象类和接口)

    一.什么是抽象类和接口 抽象类.接口与类是一个层次的概念,是java中极其重要的概念. 抽象类是从多个类中抽象出来的公共模板,提供子类均具有的功能. 接口是从多个类中抽象出来的规范,体现的是规范和实现 ...

  7. Java从零开始学三十一(DATE和Calendar类)

    一.Date类 Date类是一个相对较为简单的操作类,在使用中直接使用java.util.Date类的构造方法并进行输出就可以得到一个完整的日期 二.Calendar类 Calendar类可以将取得的 ...

  8. Java从零开始学二十九(大数操作(BigIntger、BigDecimal)

    一.BigInteger 如果在操作的时候一个整型数据已经超过了整数的最大类型长度long的话,则此数据就无法装入,所以,此时要使用BigInteger类进行操作. 不可变的任意精度的整数.所有操作中 ...

  9. Java从零开始学二十八(Math类和Random类)

    一.Math概述 提供了常用的数学运算方法和两个静态常量E(自然对数的底数)和PI(圆周率) 二.常用方法 package com.pb.demo1; public class MathTest { ...

随机推荐

  1. Set常用子类特点

    HashSet:       重写   hashCode和equals方法                                        特点:无序,唯一      底层结构是:    ...

  2. [分享]2013:Linux的黄金之年-十大杰出成就

    2013年已经过去.这一年见证了许多里程碑事件,使得2013年可以称得上是一个Linux的黄金之年.其中一些成果在FOSS和Linux世界更可以称得上是举世瞩目的成就. 1.Android的上升趋势 ...

  3. HDU 4597 Play Game (DP,记忆化搜索)

    Play Game Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total S ...

  4. BMP文件格式实例分析

    1. 以下为一个RGB565-16位BMP位图实际的部分数据: 00000000h: 42 4D 46 58 02 00 00 00 00 00 46 00 00 00 28 00 ; BMFX... ...

  5. MVC实现有关时间的进度条,使用jQuery ui的progressbar

    在电商网站中,有时候通过进度条来直观地显示用户是否到期以及用户当前的状态. 设计这样的一个Model. public class User { public int Id { get; set; } ...

  6. idea安装Lombok及使用介绍

    原文:https://blog.csdn.net/motui/article/details/79012846 Lombok使用 介绍 在项目中使用Lombok可以减少很多重复代码的书写.比如说get ...

  7. 别忽视UIImage中的方向属性, imageOrientation-转

    转 : 别忽视UIImage中的方向属性, imageOrientation

  8. python文本 判断对象里面是否是类字符串

    python文本 判断对象里面是否是类字符串 场景: 判断对象里面是否是类字符串 一般立刻会想到使用type()来实现 >>> def isExactlyAString(obj):  ...

  9. EF实体框架处理实体之间关联关系与EF延迟机制(下)

    在数据库中,表与表之间可能存在多种联系,比如,一对多,多对多的关系.当我们使用逻辑外键在数据库建立两张表之间的关系的时候,我们使用EF实体框架 必然也会将这种关系映射到我们的实体关系中来.所以,在我们 ...

  10. struts2 <s:select>标记取包含map的list的值

    如下list map.put("ID","001"); map.put ("NM","test1"); list.add ...