1、List概述 1.1、什么是List java.util.List 接口继承自 Collection 接口,是单列集合的一个重要分支,习惯性地会将实现了 List 接口的对象称为List集合。 在List集合中允许出现重复的元素,所有的元素是以一种线性方式进行存储的,在程序中可以通过索引来访问集合中的指定元素。 List集合中元素有序,即元素的存入顺序和取出顺序一致。 1.2、List特点 List是一个元素存取有序的集合。例如,存元素的顺序是11、22、33。 那么集合中,元素的存储就是按照11、 22、33的顺序完成的 List是一个带有索引的集合,通过索引就可以精确的操作集合中的元素(与数组的索引是一个道理) List中可以有重复的元素,通过元素的equals 2、List常用方法 void add(int index, E element) //指定索引添加元素 E remove(int index) //移除指定索引处元素 E get(int index
List集合 List集合类中元素有序、且可重复,集合中的每个元素都有其对应的顺序索引。 List容器中的元素都对应一个整数型的序号记载其在容器中的位置,可以根据序号存取容器中的元素。 List集合里添加了一些根据索引来操作集合元素的方法 一、ArrayList ArrayList是List接口的典型实现类,本质上,ArrayList是对象引用的一个变长数组。 注:Arrays.asList(…) 方法返回的 List 集合既不是 ArrayList 实例,也不是 Vector 实例。 Arrays.asList(…)返回值是一个固定长度的 List 集合。 List集合子类Vector这个类已经不常用了, 我就说里面的一个方法, Elements方法, 这个方法的返回值是枚举接口, 里面有两个方法, 判断和获取。
三:List集合 List集合是单列集合的一种,它所存储的元素是可以重复的。List是直接实现Collection接口类的一种。完整的lIst接口类定义如下。 更确切地讲,列表通常允许满足 e1.equals(e2) 的元素对 e1 和 e2,并且如果列表本身允许 null 元素的话,通常它们允许多个 null 元素。 如果集合为空,会报异常。 <3>ListIterator(列表迭代器) List集合特有的迭代器 接口完整定义 public interface ListIterator<E>extends Iterator<E> JDK API 2:实现类LinkedList 基本的继承关系上,同ArrayList一样不是直接继承List接口,是一个实现类。
List集合 1、List集合 1.1 List接口的方法 1.2 案例:元素的增删改查 1.3 List接口的实现类 1.3.1 ArrayList类 1.3.2 LinkedList类 1.3.3 List集合中的元素是有序、可重复的。 List集合关心集合是否有序,而不关心元素是否重复。 1.1 List接口的方法 List除可以从Collection集合继承的方法,List集合中还添加了一些根据索引来操作集合的方法。 因为添加到集合中的1,2,3,4已经自动装箱为Integer的对象了,所以如果要删除元素2,那么可以通过list.remove(Integer.valueOf(2))的方法实现或使用迭代器配合equals 集合的遍历 因为List集合也属于Collection系列的集合,此前Collection集合支持的foreach遍历和Iterator遍历对于List集合来说仍然适用,这里就不再重复,下面介绍List
返回map类型 1. xml中 <select id="selectUser " resultType="java.util.HashMap"> </select> 2.Dao接口中 Map <String,Object> selectUser(); 返回List类型 3. xml中 <select id="selectUser " resultType="java.lang.String "> </select> 2.Dao接口中 List<String> selectUser(); 返回List<Map<String,Obiect>>类型 <select id="selectUser " resultType="java.util.HashMap"> </select> 2.Dao接口中 List<Map<String,Object>> selectUser (); 版权声明
讲到List 集合 就要说到 数组。 数组和集合的区别? 相同点: 都是容器,用来存储数据的 不同点: 数组长度不可变,集合长度可以变 数组只能存储 基本类型,集合可以存储任意类型 List 接口的特点 存取有序,可以重复,有索引,可以使用普通for循环遍历 Collection 接口 中 的 remove方法 接收的是 元素,List 集合中的 remove 方法接收的是索引 常见的 List 集合 ArrayList、LinkedList 特点 ArrayList ("张2"); list.add("张3"); list.add("张4"); list.add("张1"); // ArrayList 值相同 不会覆盖 // 获取 第索引下标为 2 的元素 String s = list.get(2); System.out.println(s); // 张3 //
list; // private Iterator it; public PageModel(List list, int pageRecorders) { init (list, pageRecorders);// 通过对象集,记录总数划分 } /** */ /** * 初始化list,并告之该list每页的记录数 * * @param list * @param pageRecorders */ public void init(List list, int pageRecorders ) { this.pageRecorders = pageRecorders; this.list = list; totalRows = list.size getList() { return list; } public void setList(List list) { this.list = list
public static void main(String[] args) { //demo1(); //demo2(); //集合转数组,加泛型的 ArrayList list = new ArrayList string : arr) { System.out.println(string); } } public static void demo2() { //int[] arr = {11,22,33,44,55 }; //List list = Arrays.asList(arr); 基本数据类型的数组转换成集合,会将整个数组当作一个对象转换 //System.out.println(list); Integer [] arr = {11,22,33,44,55}; //将数组转换成集合,数组必须是引用数据类型 List list = Arrays.asList(arr); System.out.println( //将数组转换成集合 //list.add(“d”); //不能添加 System.out.println(list); } } 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。
文章目录 一、List 创建与元素获取 二、安全获取集合元素 1、getOrElse 函数 2、getOrNull函数 三、List 创建与元素获取代码示例 四、MutableList 可变列表集合 五、修改 MutableList 集合的 mutator 函数 1、添加元素运算符 += 和 删除元素运算符 -= 2、通过 Lambda 表达式筛选要删除的元素 六、List 集合遍历 七、List 2、getOrNull函数 List<T>.getOrNull(index: Int): T? ("Tom", "Jerry", "Jack") // 使用 list 集合一次性给 3 个元素赋值 val (name1, name2, name3) = list println 创建可变列表集合 val list = listOf("Tom", "Jerry", "Jack") // 使用 list 集合一次性给 2 个元素赋值, 第 1 个元素跳过
前言 在上篇文章 Java 集合框架(1)— 概述 中我们从大体上看了一下 Java 中的集合框架,包括 List 、Set、Map 接口的一些介绍并且解释了一些接口中声明的相关方法用法。 从这篇开始,我们将一起来看一下 Java 集合框架中一些具体的类的解析,了解它们的运行原理。先从 List 接口下的相关类开始。 ? > e2 = ((List<? Object o2 = e2.next(); if (! o2==null : o1.equals(o2))) return false; } return !
Java集合主要由2大体系构成,分别是Collection体系和Map体系,其中Collection和Map分别是2大体系中的顶层接口。 1 List 在Collection中,List集合是有序的,Developer可对其中每个元素的插入位置进行精确地控制,可以通过索引来访问元素,遍历元素。 (1)ArrayList实现List,得到了List集合框架基础功能; (2)ArrayList实现RandomAccess,获得了快速随机访问存储元素的功能,RandomAccess是一个标记接口, (1)LinkedList实现List,得到了List集合框架基础功能; (2)LinkedList实现Deque,Deque 是一个双向队列,也就是既可以先入先出,又可以先入后出,说简单些就是既可以在头部添加元素 (2,"!")
Java集合-List List接口(java.util.List)代表着有序的对象集合, List中包含的元素可以根据它们在List中的内部顺序进行插入、访问、迭代和删除,元素的顺序就是这个数据结构被称为列表的原因 List 和Set List和Set非常相似,都代表了一组元素的集合,但是也有一些明显的不一样, 这些差异反映在List和Set接口提供的方法中。 list.add(element1); list.add(element2); int index1 = list.indexOf(element1); int index2 = list.indexOf ("element 1"); list.add("element 2"); list.remove(0); 执行完后,List包含 element 1 和 element 2 ,索引值分别是 0 2"; String element3 = "element 3"; String element4 = "element 4"; list.add(element1); list.add(element2
Map集合和List集合哪个效率更高 List接口 List集合是一个元素有序(存储有序)、可重复的集合,集合中的每个元素都有对应的索引,以便于查询和修改,List集合是允许存储null值的。 ArrayList集合 ArrayList集合是List接口的实现类,有以下特点: 1.有序,有索引 2.元素可以重复 3.可以存储null值 4.随机访问速度快,修改快,增加/插入或者移除/删除的效率慢 5.线程不安全 注意:List集合的实现类想要实现去重复的话: 思想: 1、首先要创建一个新的集合。 2、然后使用选择排序思想进行去除重复元素。 Vector集合 Vector集合也是List接口一个实现类,底层数据结构是数组,插入和移除性能较差,线程安全,效率低。 Map集合的特点: 1.能够存储唯一的列的数据(唯一,不可重复) 2.能够存储可以重复的数据(可重复) 3.值的顺序取决于键的顺序 4.键和值都是可以存储null元素的 Map 接口常见的四个实现类
实现思路:使用jdk8的流式编程对list集合进行分组 I 对list根据条件进行分组 1.1 费率信息实体 OrganPayRate @ApiModelProperty(value = "类型 > fanliPayRates; } 1.3 查询数据 使用jdk8的流式编程对list集合进行分组 List<OrganPayRate> organPayRates = tFacFacilitatorOrganPayRateService.list //使用jdk8的流式编程对list集合进行分组 Map<EFacilitatorOrganPayRateType, List<OrganPayRate>> listMap = 根据条件进行过滤和字段筛选 需求:修改代理商角色权限时,判断是否存在权限被移除,如果存在,则穿透删除所有下级代理商相对应的权限值。 newCodeList.contains(s); }).collect(Collectors.toList()); //2.
既然我们知道他是在集合中,那么我就顺着他的父类寻找,先看一下List,没有发现,List在向上是collection,这时我们看看他的方法: @SuppressWarnings({"rawtypes", > list, Random rnd) { int size = list.size(); if (size < SHUFFLE_THRESHOLD || list instanceof oldCapacity = elementData.length; int newCapacity = oldCapacity + (oldCapacity >> 1);//右移一位除以2 elementData, newCapacity); } 缺点是向指定的索引位置插入对象或删除对象的速度较慢.因为指向索引位置插入对象时,会将指定索引位置及之后的所有对象相应向后移动一位 Vector集合与 ArrayList集合没有本质区别,因为Vector中方法和ArrayList的方法是一致的,但是每个方法上都有synchronized 关键字,所以说Vector集合是线程安全,但是也正因为如此,vector
import java.util.ArrayList; import java.util.List; interface Animal { // 动物 public String getName () ; public int getAge() ; } class Zoo { private List<Animal> animals = new ArrayList<Animal> <Animal> search(String keyWord) { List<Animal> result = new ArrayList<Animal>() ; for zoo.add(new Dog("黑狗", 1)); zoo.add(new Dog("斑点狗", 1)); zoo.add(new Tiger("斑点虎", 2) ); zoo.add(new Tiger("黑虎", 2)); zoo.add(new Tiger("花虎", 2)); zoo.delete(new Dog
java集合可以说无论是面试、刷题还是工作中都是非常常用的。抛去Iterable , 从Collection 级别说起,整个java集合主要分为Collection 和Map 两大类。 List 简单来说就是存取有序的集合,并且有索引值,元素可以重复。 ? ArrayList 结构及构造函数 ? 删除 对于删除而言,有2个重载方法,一个是删除某个下标的元素,另外一个是删除某个特定的元素。 ? LinkedList 结构及构造函数 值得注意的是LinkedList 即实现了List 接口,也实现了Deque ,本篇文章仅讨论实现了List 接口的部分。 ? 可以看到不同于ArrayList 增长为原来的1.5倍,Vector 是增长为原来的2倍。
(list);//[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] System.out.println(subList);//[1, 2, 3, 4, 5] (subList);//[2, 3, 4, 5] } 当使用subList()方法获得集合后增加元素,原(父)集合也会增加。 (list);//[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] System.out.println(subList);//[1, 2, 3, 4, 5] (list); System.out.println(unmodifiableList);//[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] //删除原集合元素 extends E> list) { super(list); this.list = list; } 因为不可变集合的成员变量的引用是指向原集合的,所以当原集合改变时
使用java8新特性stream进行List去重 List newList = list.stream().distinct().collect(Collectors.toList()); System.out.println ("java8新特性stream去重:"+newList); 需求 list的方法 说明 备注 交集 listA.retainAll(listB) listA内容变为listA和listB都存在的对象 listB的内容去重 listB不变 并集 listA.removeAll(listB) listA.addAll(listB) 为了去重,listA先取差集,然后追加全部的listB listB不变 如果list
2. 三、List 的常用方法详解 1. 添加元素 // 在末尾添加 list.add("Apple"); // 在指定位置插入 list.add(1, "Banana"); // 插入到索引 1 2. 子列表操作 // 获取子列表 List<String> subList = list.subList(1, 3); // 包含索引 1 和 2 的元素 四、List 的线程安全版本 1. 2. CopyOnWriteArrayList —— 写时复制的线程安全 List 核心特性 写时复制:每次修改(add, remove)都会创建一个新数组副本。 CopyOnWriteArrayList 写时复制,读无锁 最后一句话 List 是 Java 集合框架中最基础、最常用的接口之一。