Java集合中List的用法
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的用法的更多相关文章
- Java集合中Set的常见问题及用法
在这里演示的案例是衔接Java集合中的List(点击查看)那篇博文的,本节我们学习的Set的用法. Set是Collection的一个重要的子接口,Set中的元素是无序排列的,并且元素不可以重复,被称 ...
- Java集合中迭代器的常用用法
该例子展示了一个Java集合中迭代器的常用用法public class LinkedListTest { public static void main(String[] args) { List&l ...
- Java集合中Comparator和Comparable接口的使用
在Java集合中,如果要比较引用类型泛型的List,我们使用Comparator和Comparable两个接口. Comparable接口 -- 默认比较规则,可比较的 实现该接口表示:这个类的实例可 ...
- JAVA语言中冒号的用法
近来由于本人要介入android平台的开发,所以就买了本JAVA语言的书学习.学习一段时间来,我的感觉是谭浩强就是厉害,编写的<C编程语言>系列丛书不愧是经典.书中对C语言的介绍既系统又全 ...
- java stream中Collectors的用法
目录 简介 Collectors.toList() Collectors.toSet() Collectors.toCollection() Collectors.toMap() Collectors ...
- java集合中List与set的区别
java集合中List与set的区别. List可以存储元素为有序性并且元素可以相同. set存储元素为无序性并且元素不可以相同. 下面贴几段代码感受一下: ArrayL ...
- Java集合中的LinkedHashMap类
jdk1.8.0_144 本文阅读最好先了解HashMap底层,可前往<Java集合中的HashMap类>. LinkedHashMap由于它的插入有序特性,也是一种比较常用的Map集合. ...
- 【java集合框架源码剖析系列】java源码剖析之java集合中的折半插入排序算法
注:关于排序算法,博主写过[数据结构排序算法系列]数据结构八大排序算法,基本上把所有的排序算法都详细的讲解过,而之所以单独将java集合中的排序算法拿出来讲解,是因为在阿里巴巴内推面试的时候面试官问过 ...
- Java集合中List,Set以及Map等集合体系详解
转载请注明出处:Java集合中List,Set以及Map等集合体系详解(史上最全) 概述: List , Set, Map都是接口,前两个继承至collection接口,Map为独立接口 Set下有H ...
随机推荐
- Nginx + spawn-fcgi- Ubuntu中文
Nginx - Ubuntu中文 页面 讨论 查看源代码 历史 导航 首页 最近更改 随机页面 页面分类 帮助 编辑 编辑指南 沙盒 新闻动态 字词处理 工具 链入页面 相关更改 特殊页面 打印版 ...
- underflow 、overflow 下溢和上溢
在strtoull函数返回值中,就提到上溢和下溢的问题,现在把这俩个概念拿出来涨涨见识! 上溢 Overflow 是当一个超长的数据进入到缓冲区时,超出部分被写入上级缓冲区,上级缓冲区存放的可能是数 ...
- JQ实现右下角scrollTop()事件
废话不多说,先贴代码 <script> $(document).ready(function(){ $("#id").hide(); $(function(){ // ...
- C生成随机数,奇葩问题
今天需要生成一个随机数,奇怪的问题发生了. #include <stdio.h> #include <stdlib.h> #include <time.h> #de ...
- Job中织梦标签的调用
织梦CMS是一个好东东, 可以让一个网站更好维护和管理, 唯一让我感到忧桑的就是经常在搭后台的时候记不住那些标签,,无奈只能去看手册,有相同的案例直接COPY过来,直接用就OK~~~其实CMS这个东西 ...
- Slave_SQL_Running: No mysql同步故障解决方法
Slave_SQL_Running: No mysql同步故障解决 今天检查数据库发现一台MySQL Slave未和主机同步,查看Slave状态:mysql> show slave s ...
- 2015年12月02日 GitHub入门学习(四)Git操作
序,学习使用Git是一项新技能,你将了解到Git与SubVersion的区别. 一.基本操作 git init 初始化仓库,请实际建立一个目录并初始化仓库,.git目录里存储着管理当前目录内容所需的仓 ...
- ZOJ 3711 Give Me Your Hand
Give Me Your Hand Time Limit: 2 Seconds Memory Limit: 131072 KB Special Judge BellyWhite a ...
- POJ 1061 青蛙的约会
青蛙的约会 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 82859 A ...
- POJ 1496 Word Index
组合数学....和上一题是一样的.... Word Index Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 4303 Acce ...