第六章 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 接口

相关推荐
add45a几秒前
C++中的工厂方法模式
开发语言·c++·算法
java1234_小锋几秒前
Java高频面试题:Spring-AOP通知和执行顺序?
java·开发语言·spring
番茄去哪了5 分钟前
Java基础面试题day02
java·开发语言·面向对象编程
xushichao19899 分钟前
C++中的工厂模式高级应用
开发语言·c++·算法
njsgcs9 分钟前
c# solidworks 折弯系数检查
开发语言·c#
SuperEugene13 分钟前
Vue3 + Element Plus 表格实战:批量操作、行内编辑、跨页选中逻辑统一|表单与表格规范篇
开发语言·前端·javascript
2501_9249526916 分钟前
C++模块化编程指南
开发语言·c++·算法
2401_8319207420 分钟前
基于C++的爬虫框架
开发语言·c++·算法
我是咸鱼不闲呀21 分钟前
力扣Hot100系列22(Java)——[图论]总结(岛屿数量,腐烂的橘子,课程表,实现Trie(前缀树))
java·leetcode·图论
1104.北光c°21 分钟前
深入浅出 Elasticsearch:从搜索框到精准排序的架构实战
java·开发语言·elasticsearch·缓存·架构·全文检索·es