IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 【JAVA集合III-List】 -> 正文阅读

[数据结构与算法]【JAVA集合III-List】

1.List接口

(1)List接口是Collection接口的子接口,看源码:
在这里插入图片描述
(2)List集合类特点

  • List集合类中的元素有序(即添加顺序和取出顺序一致)、且可重复
  • List集合中的每一个元素都有其对应的顺序索引,即支持索引。
  • List容器中的元素都对应一个整数型的序号,记载其在容器中的位置,可以根据序号存取容器中的元素。
  • JDK API中List接口的实现类

下图仅列出List接口的部分实现类,因为太多了:
在这里插入图片描述

2.List接口常用方法

以下方法来自List接口源码:

public interface List<E> extends Collection<E> {

      int size();//集合大小
      
      boolean isEmpty();//判断集合是否为空
      
      boolean contains(Object o);//判断集合是否包含元素o
      
      Iterator<E> iterator();//迭代器方法,用于遍历集合元素
      
      Object[] toArray();//集合转换为数组
      
      <T> T[] toArray(T[] a);//泛型方法,集合转换为数组
      
      boolean remove(Object o);//删除指定元素
      
      boolean containsAll(Collection<?> c);//当前集合是否包含集合c
      
      boolean addAll(Collection<? extends E> c);//添加集合c到当前集合
      
      boolean addAll(int index, Collection<? extends E> c);//在指定位置添加集合c到当前集合
      
      boolean removeAll(Collection<?> c);//删除当前集合中的所有c(c为集合)
      
      boolean retainAll(Collection<?> c);//保留当前集合中所有的集合c
      
      default void replaceAll(UnaryOperator<E> operator) {//替换操作
        Objects.requireNonNull(operator);
        final ListIterator<E> li = this.listIterator();
        while (li.hasNext()) {
            li.set(operator.apply(li.next()));
        }
    }

      default void sort(Comparator<? super E> c) {//排序集合元素,要传入一个比较器
        Object[] a = this.toArray();
        Arrays.sort(a, (Comparator) c);
        ListIterator<E> i = this.listIterator();
        for (Object e : a) {
            i.next();
            i.set((E) e);
        }
    }

     void clear();//清空集合

     boolean equals(Object o);//比较元素是否相等

     int hashCode();//计算集合的hashcode值

     E get(int index);//泛型方法,获得指定索引的集合元素
     
    E set(int index, E element);//设置指定索引的集合元素值
    
    void add(int index, E element);//添加指定索引的元素值
    
    E remove(int index);//删除指定位置的值
    
    int indexOf(Object o);//获取元素的索引



}

重点讲述方法:

   * @param a the array into which the elements of this list are to
     *          be stored, if it is big enough; otherwise, a new array of the
     *          same runtime type is allocated for this purpose.
     * @return an array containing the elements of this list
     * @throws ArrayStoreException if the runtime type of the specified array
     *         is not a supertype of the runtime type of every element in
     *         this list
     * @throws NullPointerException if the specified array is null
     */
    <T> T[] toArray(T[] a);
<T> T[] toArray(T[] a);:实现链表到数组的转换,这里的a指定的存储数组

如果a的长度小于当前列表大小,则不进行转换
如果a的长度大于当前列表大小,多余的位置的一个会用null标记
注意:throws ArrayStoreException 如果指定数组的运行时类型
不是每个元素的运行时类型的超类型,保证指定的数组类型为链表元素的超类型。

List<Integer> list3 = new ArrayList<>();
        list3.add(1);
        list3.add(2);
        list3.add(3);
        //这里使用的数组类型必须为list3中的超类才行,而且
        //要保证数组大小大于等于链表大小。
        Integer[] objects = new Integer[]{8, 8,8};
        list3.toArray(objects);
        System.out.println(Arrays.asList(objects));

3.练习

上述方法测试(部分),剩余内容可以自己去测:

package Collection.list;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

/**
 * @author rql
 * @date 2022/4/26 - 16:50
 */
public class ListTest {

    public static void main(String[] args) {
        List list=new ArrayList();
        list.add(1);
        list.add(2);
        list.add("背景");
        list.add(new Cat("小欢",3));

        //        int size();
        System.out.println("当前集合大小:"+list.size());

        //
        //        boolean isEmpty();

        System.out.println("当前集合是否为空:"+list.isEmpty());
        //
        //        boolean contains(Object o);
        System.out.println("是否包含2:"+list.contains(2));
        //
        //        Iterator<E> iterator();
        System.out.println("迭代器遍历集合:");
        Iterator iterator = list.iterator();
        while (iterator.hasNext()){
            Object next = iterator.next();
            System.out.println(next);
        }
        //
        //        Object[] toArray();
        System.out.println("集合转化为数组:");
        Object[] array = list.toArray();//因为没有指定集合的泛型类型,默认为Object类型
        for (Object o : array) {
            System.out.println(o);
        }
        //
        //      <T> T[] toArray(T[] a);

        //
        //        boolean remove(Object o);
        System.out.println("remove的使用:");
        //Object remove = list.remove(1);//删除索引为1的元素:2
        //boolean remove = list.remove("1");//删除元素为1
        //System.out.println(remove);
        Iterator iterator1 = list.iterator();
        while (iterator1.hasNext()){
            System.out.println(iterator1.next());
        }
        //
        //        boolean containsAll(Collection<?> c);
        System.out.println("containsAll:判断当前集合是否包含指定的集合元素:");
        ArrayList list1 = new ArrayList();
        list1.add(1);
        list1.add(2);
        System.out.println(list.containsAll(list1));//true
        //
        //        boolean addAll(Collection<? extends E> c);
        System.out.println("addAll(Collection<? extends E> c)添加集合,该集合可以是E或E的子类");
        list.addAll(list1);
        iterator=list.iterator();
        while (iterator.hasNext()){
            System.out.println(iterator.next());
        }
        //
        //        boolean addAll(int index, Collection<? extends E> c);在指定位置添加一个集合
        System.out.println("boolean addAll(int index, Collection<? extends E> c)");
        list.addAll(1,list1);
        iterator=list.iterator();
        while (iterator.hasNext()){
            System.out.println(iterator.next());
        }

        //
        //        boolean removeAll(Collection<?> c);
        System.out.println("boolean removeAll(Collection<?> c):");
//        list.removeAll(list1);
//        iterator=list.iterator();
//        while (iterator.hasNext()){
//            System.out.println(iterator.next());
//        }
        //
        //        boolean retainAll(Collection<?> c);保留集合list中的c
        System.out.println("boolean retainAll(Collection<?> c):");
        list.retainAll(list1);
        iterator=list.iterator();
        while (iterator.hasNext()){
            System.out.println(iterator.next());
        }
        //
        //        default void replaceAll(UnaryOperator<E> operator) {
        //            Objects.requireNonNull(operator);
        //            final ListIterator<E> li = this.listIterator();
        //            while (li.hasNext()) {
        //                li.set(operator.apply(li.next()));
        //            }
        //        }
        //
        //        default void sort(Comparator<? super E> c) {
        //            Object[] a = this.toArray();
        //            Arrays.sort(a, (Comparator) c);
        //            ListIterator<E> i = this.listIterator();
        //            for (Object e : a) {
        //                i.next();
        //                i.set((E) e);
        //            }
        //        }
        //
        //        void clear();
        System.out.println("clear:清空列表");
        list.clear();
        System.out.println(list);

        //
        //        boolean equals(Object o);
        //
        //        int hashCode();计算集合的hashcode值
        int i = list.hashCode();
        System.out.println(i);
        //
        //        E get(int index);
        //
        //        E set(int index, E element);
        //
        //        void add(int index, E element);
        //
        //        E remove(int index);
        //
        //        int indexOf(Object o);
    }
}

class Cat{
    public String name;
    public int age;

    public Cat(String name, int age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public String toString() {
        return "Cat{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}



  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-04-28 12:04:59  更:2022-04-28 12:08:24 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 17:15:03-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码