Java集合中List的用法

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

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

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

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

 1 /**
 2  * 课程类
 3  * @author lenovo
 4  *
 5  */
 6 public class KeCheng {
 7
 8     public String id;
 9
10     public String name;
11
12     public KeCheng(String id,String name){
13         this.id = id;
14         this.name = name;
15     }
16
17 }

创建一个学生类

 1 import java.util.HashSet;
 2 import java.util.Set;
 3
 4 /**
 5  * 学生类
 6  * @author lenovo
 7  *
 8  */
 9 public class Student {
10
11     public String id;
12
13     public String name;
14
15     public Set kecheng;
16
17     public Student(String id,String name){
18         this.id = id;
19         this.name = name;
20         this.kecheng = new HashSet();
21     }
22
23 }

创建一个备选课程的类

 1 /**
 2  * 备选课程类
 3  * @author lenovo
 4  *
 5  */
 6 public class ListTest {
 7
 8     //用于存放备选课程的List
 9     public List beixuan;
10
11     public ListTest(){
12         this.beixuan = new ArrayList();
13     }
14 }

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

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

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

 1 /*
 2      * 使用for循环遍历课程的方法
 3      */
 4     public void getKC(){
 5         int size = beixuan.size();
 6         System.out.println("使用for遍历课程:");
 7         for (int i = 0; i < size; i++) {
 8             KeCheng kc = (KeCheng) beixuan.get(i);
 9             System.out.println("课程:"+kc.id+":"+kc.name+";");
10         }
11     }

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

 1 /*
 2      * 使用Iterator迭代器遍历课程
 3      */
 4     public void testIterator(){
 5         Iterator it = beixuan.iterator();
 6         System.out.println("使用Iterator遍历课程:");
 7         while(it.hasNext()){
 8             KeCheng kc = (KeCheng) it.next();
 9             System.out.println("课程:"+kc.id+":"+kc.name+";");
10         }
11
12     }
13
14     /*
15      * 使用for each遍历课程
16      */
17     public void testForeach(){
18         System.out.println("使用for each遍历课程:");
19         for(Object obj : beixuan){
20             KeCheng kc = (KeCheng)obj;
21             System.out.println("课程:"+kc.id+":"+kc.name+";");
22         }
23     }
24     

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

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

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

 1 /*
 2      * 使用remove方法删除课程
 3      */
 4     public void testRemove(){
 5         KeCheng kc = (KeCheng) beixuan.get(0);
 6         System.out.println("我是课程:"+kc.id+":"+kc.name+";即将被删除");
 7         boolean b = beixuan.remove(kc);
 8         if(b){
 9             System.out.println("成功删除课程");
10             testForeach();
11         }
12     }

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

 1 /*
 2      * 使用removeAll方法删除课程
 3      */
 4     public void testRemoveAll(){
 5         System.out.println("即将删除4和5位置上的课程");
 6         KeCheng[] kc = {(KeCheng) beixuan.get(4),(KeCheng) beixuan.get(5)};
 7         beixuan.removeAll(Arrays.asList(kc));
 8         System.out.println("课程删除成功");
 9         testForeach();
10     }
时间: 2024-08-30 05:05:57

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

Java集合的线程安全用法

线程安全的集合包含2个问题 1.多线程并发修改一 个 集合 怎么办? 2.如果迭代的过程中 集合 被修改了怎么办? a.一个线程在迭代,另一个线程在修改 b.在同一个线程内用同一个迭代器对象进行迭代.修改.迭代.修改. . . 共有有3种解决方案 1.用老的Vector/Hashtable类,上面2个问题都不用担心. Vector/Hashtable所提供的所有方法都是 synchronized的.如果 迭代的过程中数据结构被修改了,迭代器可以反映最新的修改,也不会抛异常.但这种方法效率低下,不

java集合中List与set的区别

java集合中List与set的区别.     List可以存储元素为有序性并且元素可以相同.     set存储元素为无序性并且元素不可以相同.     下面贴几段代码感受一下: ArrayList list = new ArrayList();//构造出List对象 list.add(1); list.add("string"); list.add(true); list.add(3.14); list.add(null); for(int i = 0; i < size()

Java集合中的LinkedHashMap类

jdk1.8.0_144 本文阅读最好先了解HashMap底层,可前往<Java集合中的HashMap类>. LinkedHashMap由于它的插入有序特性,也是一种比较常用的Map集合.它继承了HashMap,很多方法都直接复用了父类HashMap的方法.本文将探讨LinkedHashMap的内部实现,以及它是如何保证插入元素是按插入顺序排序的. 在分析前可以先思考下,既然是按照插入顺序,并且以Linked-开头,就很有可能是链表实现.如果纯粹以链表实现,也不是不可以,LinkedHashM

java集合中Comparable和Comparator辨析

一.Comparable和Comparator简介 在对集合元素进行比较时一般使用TreeSet.对于简单的数据类型,TreeSet可以直接进行比较.但是对于复杂的数据类型,比如自己定义的数据类型或者类,就需要自己设置比较方法与比较规则了,这时就需要使用Comparable和Comparator. Comparable和Comparator都是用来实现集合中的排序的,只是Comparable是在集合内图定义的方法实现排序,而Comparator是在集合外部实现的排序.所以如果想对结合排序,需要在

如何删除JAVA集合中的元素

经常我们要删除集合中的某些元素.有些可能会这么写. public void operate(List list){ for (Iterator it = list.iterator(); it.hasNext();) { String str = (String)it.next(); if (str.equals("chengang")){ list.remove(str); } } } 这种写法一运行就会报如下异常: Exception in thread "main&qu

Java集合中对象排序

集合中的对象排序需求还是比较常见的,当然我们可以重写equals方法,循环比较:同时Java为我们提供了更易使用的APIs.当需要排序的集合或数组不是单纯的数字型时,通常可以使用Comparator或Comparable,以简单的方式实现对象排序或自定义排序. 下面通过两个例子分别用Comparable和Comparator实现对User对象中年龄排序. Comparable接口方式 类自身实现Comparable接口,实现该接口中的compareTo方法. import java.util.A

java集合中对象某属性比较排序Comparable与Comparator

要对集合中的对象的某属性进行排序有两种方式. a. 一种是要排序对象类实现comparable接口的compareTo方法:然后把对象放入list:然后调用Collections.sort(list);b. 一种是不对要排序对象类做任何改动,创建Comparator接口的实现类C:然后 把对象放入list:然后调用Collections.sort(list, C); a.eg ---------------------------------- 1 public class User imple

java集合中的一些易混淆的知识点

(一) collection和collections 这两者均位于java.util包下,不同的是: collection是一个集合接口,有ListSet等常见的子接口,是集合框架图的第一个节点,,提供了对集合对象进行基本操作的一系列方法. 常见的方法有: boolean add(E e) 往容器中添加元素:int size() 返回collection的元素数:boolean isEmpty() 判断此容器是否为空: boolean contains(Object o) 如果此collecti

Java集合中迭代器

迭代器的作用:就是用于抓取集合中的元素. 迭代器的方法: hasNext() 问是否有元素可遍历.如果有元素可以遍历,返回true,否则返回false .next() 获取元素...remove() 移除迭代器最后一次返回 的元素 NoSuchElementException 没有元素的异常. 出现的原因: 没有元素可以被迭代了... import java.util.ArrayList; import java.util.Collection; import java.util.Iterato