第六章 6.8 List

List基础知识

List家族特点:有序可重复

List接口常用方法:

List接口特有迭代

源码LisrIterator继承Iterator

通用方法+特有方法

void add(E e)

添加元素

java 复制代码
ListIterator<String> li = names.listIterator();
while (li.hasNext()){
    String name = li.next();
    if("lisi".equals(name)){
        li.add("李四");
   }
System.out.println(names);

E hasPrevous()

判断当前光标指向的上一个位置是否存在元素;

java 复制代码
ListIterator<String>li =names.listIterator();
System.out.println("光标当前指向的位置的上一个位置是否有元素:"+ li.hasPrevious());
while(li.hasNext()){
    String name = li.next();
    System.out.println(name);
}

int nextindex()

获取光标指向的那个位置的下标

int previousIndex()

获取光标指向的那个位置的上标

java 复制代码
//int nextIndex();获取光标指向的那个位置的下标
ListIterator<String> li = names.listIterator();
while(li.hasNext()){
    String name = li.next();
    if("lisi".equals(name)){ // 当前取出的元素是"lisi"
        System.out.println(li.nextIndex());//2
}
    //int previousIndex();获取光标指向的那个位置的上一个位置的下标                
    System.out.println(li.previousIndex());//1
System.out.println(name);
}

set(E e)

设置的是光标以上的那个元素

next()源码解析

光标从0下标开始,当执行i.next()方法时,根据源码。光标先下移一位,但是返回取出的元素还为光标上一位的元素。

sort()排序方法

静态方法

使用comparable()指定排队规则

重写comparable接口方法自定义排序规则

sort()源码:

在类user中重写comparable()方法,sort传入user,形参就为 Comparable<User> user = new User(),就调用User中重写的comparable()方法了,就为自定义的排序规则。

java 复制代码
public static <T> void sort(T[] a, Comparator<? super T> c) {
        if (c == null) {
            sort(a);
        } else {
            if (LegacyMergeSort.userRequested)
                legacyMergeSort(a, c);
            else
                TimSort.sort(a, 0, a.length, c, null, 0, 0);
        }
    }

使用Comparator<T>自定义排队规则

方法1:要自定义一个额外的类实现这个接口

方法2:使用匿名内部类:直接 new 接口

相关推荐
庸俗今天不摸鱼10 分钟前
Canvas进阶-4、边界检测(流光,鼠标拖尾)
开发语言·前端·javascript·计算机外设
菠菠萝宝11 分钟前
【Java八股文】10-数据结构与算法面试篇
java·开发语言·面试·红黑树·跳表·排序·lru
奔跑吧邓邓子14 分钟前
【Python爬虫(36)】深挖多进程爬虫性能优化:从通信到负载均衡
开发语言·爬虫·python·性能优化·负载均衡·多进程
不会Hello World的小苗18 分钟前
Java——链表(LinkedList)
java·开发语言·链表
lsx20240630 分钟前
Perl 面向对象编程指南
开发语言
Allen Bright1 小时前
【Java基础-46.3】Java泛型通配符详解:解锁类型安全的灵活编程
java·开发语言
柃歌1 小时前
【UCB CS 61B SP24】Lecture 7 - Lists 4: Arrays and Lists学习笔记
java·数据结构·笔记·学习·算法
柃歌1 小时前
【UCB CS 61B SP24】Lecture 4 - Lists 2: SLLists学习笔记
java·数据结构·笔记·学习·算法
画个逗号给明天"1 小时前
C++STL容器之list
开发语言·c++
是姜姜啊!1 小时前
redis的应用,缓存,分布式锁
java·redis·spring