List接口是Collection接口的子接口,List有一个重要的实现类--ArrayList类,List中的元素是有序排列的而且可重复,所以被称为是序列。

List可以精确的控制每个元素的插入位置,或删除某个位置元素,它的实现类ArrayList底层是由数组实现的。

List中有增删改查的方法,我们可以通过例子演示:

我们通过对学生选课,来演示List中对课程增删改查的方法

 /**
* 课程类
* @author lenovo
*
*/
public class KeCheng { public String id; public String name; public KeCheng(String id,String name){
this.id = id;
this.name = name;
} }

创建一个学生类

 import java.util.HashSet;
import java.util.Set; /**
* 学生类
* @author lenovo
*
*/
public class Student { public String id; public String name; public Set kecheng; public Student(String id,String name){
this.id = id;
this.name = name;
this.kecheng = new HashSet();
} }

创建一个备选课程的类

 /**
* 备选课程类
* @author lenovo
*
*/
public class ListTest { //用于存放备选课程的List
public List beixuan; public ListTest(){
this.beixuan = new ArrayList();
}
}

可以使用List中add方法添加课程

 /*
* 用来往beixuan里添加备选课程的方法
*/
public void kcAdd(){ //创建一个课程的对象,调用add方法,添加到备选课程的List中
KeCheng kc = new KeCheng("1","数据结构");
beixuan.add(kc); KeCheng kc2 = new KeCheng("2","C语言");
beixuan.add(0, kc2); KeCheng[] kcArr = {new KeCheng("3","大学语文"),new KeCheng("4","线性代数")};
beixuan.addAll(Arrays.asList(kcArr)); KeCheng[] kcArr2 = {new KeCheng("5","艺术设计"),new KeCheng("6","计算机基础")};
beixuan.addAll(2, Arrays.asList(kcArr2)); }

使用get方法取出指定位置上的内容,并用for循环遍历出课程的内容

 /*
* 使用for循环遍历课程的方法
*/
public void getKC(){
int size = beixuan.size();
System.out.println("使用for遍历课程:");
for (int i = 0; i < size; i++) {
KeCheng kc = (KeCheng) beixuan.get(i);
System.out.println("课程:"+kc.id+":"+kc.name+";");
}
}

遍历List的内容,除了使用for循环外,还可以使用迭代器、foreach等方法

 /*
* 使用Iterator迭代器遍历课程
*/
public void testIterator(){
Iterator it = beixuan.iterator();
System.out.println("使用Iterator遍历课程:");
while(it.hasNext()){
KeCheng kc = (KeCheng) it.next();
System.out.println("课程:"+kc.id+":"+kc.name+";");
} } /*
* 使用for each遍历课程
*/
public void testForeach(){
System.out.println("使用for each遍历课程:");
for(Object obj : beixuan){
KeCheng kc = (KeCheng)obj;
System.out.println("课程:"+kc.id+":"+kc.name+";");
}
}

修改List中的元素,可以使用set方法

 /*
* 使用set方法添加课程
*/
public void testModify(){
beixuan.set(0, new KeCheng("7","毛概"));
}

删除List中的元素有两种方法,一是使用remove方法

 /*
* 使用remove方法删除课程
*/
public void testRemove(){
KeCheng kc = (KeCheng) beixuan.get(0);
System.out.println("我是课程:"+kc.id+":"+kc.name+";即将被删除");
boolean b = beixuan.remove(kc);
if(b){
System.out.println("成功删除课程");
testForeach();
}
}

还可以使用removeAll方法删除一个课程类型的数组

 /*
* 使用removeAll方法删除课程
*/
public void testRemoveAll(){
System.out.println("即将删除4和5位置上的课程");
KeCheng[] kc = {(KeCheng) beixuan.get(4),(KeCheng) beixuan.get(5)};
beixuan.removeAll(Arrays.asList(kc));
System.out.println("课程删除成功");
testForeach();
}

Java集合中List的用法的更多相关文章

  1. Java集合中Set的常见问题及用法

    在这里演示的案例是衔接Java集合中的List(点击查看)那篇博文的,本节我们学习的Set的用法. Set是Collection的一个重要的子接口,Set中的元素是无序排列的,并且元素不可以重复,被称 ...

  2. Java集合中迭代器的常用用法

    该例子展示了一个Java集合中迭代器的常用用法public class LinkedListTest { public static void main(String[] args) { List&l ...

  3. Java集合中Comparator和Comparable接口的使用

    在Java集合中,如果要比较引用类型泛型的List,我们使用Comparator和Comparable两个接口. Comparable接口 -- 默认比较规则,可比较的 实现该接口表示:这个类的实例可 ...

  4. JAVA语言中冒号的用法

    近来由于本人要介入android平台的开发,所以就买了本JAVA语言的书学习.学习一段时间来,我的感觉是谭浩强就是厉害,编写的<C编程语言>系列丛书不愧是经典.书中对C语言的介绍既系统又全 ...

  5. java stream中Collectors的用法

    目录 简介 Collectors.toList() Collectors.toSet() Collectors.toCollection() Collectors.toMap() Collectors ...

  6. java集合中List与set的区别

       java集合中List与set的区别.     List可以存储元素为有序性并且元素可以相同.     set存储元素为无序性并且元素不可以相同.     下面贴几段代码感受一下: ArrayL ...

  7. Java集合中的LinkedHashMap类

    jdk1.8.0_144 本文阅读最好先了解HashMap底层,可前往<Java集合中的HashMap类>. LinkedHashMap由于它的插入有序特性,也是一种比较常用的Map集合. ...

  8. 【java集合框架源码剖析系列】java源码剖析之java集合中的折半插入排序算法

    注:关于排序算法,博主写过[数据结构排序算法系列]数据结构八大排序算法,基本上把所有的排序算法都详细的讲解过,而之所以单独将java集合中的排序算法拿出来讲解,是因为在阿里巴巴内推面试的时候面试官问过 ...

  9. Java集合中List,Set以及Map等集合体系详解

    转载请注明出处:Java集合中List,Set以及Map等集合体系详解(史上最全) 概述: List , Set, Map都是接口,前两个继承至collection接口,Map为独立接口 Set下有H ...

随机推荐

  1. Nginx + spawn-fcgi- Ubuntu中文

    Nginx - Ubuntu中文 页面 讨论 查看源代码 历史   导航 首页 最近更改 随机页面 页面分类 帮助 编辑 编辑指南 沙盒 新闻动态 字词处理 工具 链入页面 相关更改 特殊页面 打印版 ...

  2. underflow 、overflow 下溢和上溢

    在strtoull函数返回值中,就提到上溢和下溢的问题,现在把这俩个概念拿出来涨涨见识! 上溢  Overflow 是当一个超长的数据进入到缓冲区时,超出部分被写入上级缓冲区,上级缓冲区存放的可能是数 ...

  3. JQ实现右下角scrollTop()事件

    废话不多说,先贴代码 <script> $(document).ready(function(){ $("#id").hide(); $(function(){ // ...

  4. C生成随机数,奇葩问题

    今天需要生成一个随机数,奇怪的问题发生了. #include <stdio.h> #include <stdlib.h> #include <time.h> #de ...

  5. Job中织梦标签的调用

    织梦CMS是一个好东东, 可以让一个网站更好维护和管理, 唯一让我感到忧桑的就是经常在搭后台的时候记不住那些标签,,无奈只能去看手册,有相同的案例直接COPY过来,直接用就OK~~~其实CMS这个东西 ...

  6. Slave_SQL_Running: No mysql同步故障解决方法

    Slave_SQL_Running: No mysql同步故障解决      今天检查数据库发现一台MySQL Slave未和主机同步,查看Slave状态:mysql> show slave s ...

  7. 2015年12月02日 GitHub入门学习(四)Git操作

    序,学习使用Git是一项新技能,你将了解到Git与SubVersion的区别. 一.基本操作 git init 初始化仓库,请实际建立一个目录并初始化仓库,.git目录里存储着管理当前目录内容所需的仓 ...

  8. ZOJ 3711 Give Me Your Hand

    Give Me Your Hand Time Limit: 2 Seconds      Memory Limit: 131072 KB      Special Judge BellyWhite a ...

  9. POJ 1061 青蛙的约会

                            青蛙的约会 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 82859   A ...

  10. POJ 1496 Word Index

    组合数学....和上一题是一样的.... Word Index Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 4303 Acce ...