List中常见的方法和五种遍历方式

有序:存取的顺序一致

有索引:可以通过索引操作元素

可重复:存储的元素可以重复

java 复制代码
package mylist;

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

public class A01_LIstDemo1 {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("aaa");
        list.add("bbb");
        list.add("ccc");
        //void add(int index,E element)
        //细节:原来索引上的元素会依次往后排
        list.add(1,"qqq");
        //E remove(int Index)
        //删除元素
        //在调用方法的时候,如果出现了重载现象
        //优先调用,实参跟形参类型一致的那个方法
        String remove = list.remove(2);
        System.out.println(remove);
        System.out.println(list);
        //修改指定索引处的元素,返回被修改的值
        list.set(1,"www");
        System.out.println(list);
        //返回指定索引元素
        String s = list.get(1);
        System.out.println(s);
    }
}

List集合的遍历方式

迭代器遍历,列表迭代器遍历,增强for遍历,Lambda表达式遍历,普通for循环(因为List集合存在索引)

java 复制代码
package mylist;

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

public class A02_ListDemo2 {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("aaa");
        list.add("bbb");
        list.add("ccc");
        //1.迭代器
//        Iterator<String> it = list.iterator();
//        while (it.hasNext()){
//            String next = it.next();
//            System.out.println(next);
//        }
        //2.增强for
        //下面的变量s,其实就是一个第三方的变量而已
        //在循环的过程中,依次表示集合中的每一个元素
//        for (String s : list) {
//            System.out.println(s);
//        }
        //3.Lambda表达式
        //forEach方法的底层其实就是一个循环遍历,依次得到集合中的每一个元素
        //并把每一个元素传递给下面的accept方法
        //accept方法的形参s,依次表示集合中的每一个元素
//        list.forEach( s-> System.out.println(s));
        //4.普通for循环
//        for (int i = 0; i < list.size(); i++) {
//            String s = list.get(i);
//            System.out.println(s);
//        }
        //5.列表迭代器
//        ListIterator<String> it = list.listIterator();
//        while (it.hasNext()){
//            String str = it.next();
//           if ("bbb".equals(str)){
//                it.add("qqq");
//            }
//        }
//        System.out.println(list);
//    }

}
相关推荐
阿让啊2 小时前
C语言strtol 函数使用方法
c语言·数据结构·c++·单片机·嵌入式硬件
superlls5 小时前
(算法 哈希表)【LeetCode 349】两个数组的交集 思路笔记自留
java·数据结构·算法
Ripple123126 小时前
数据结构:顺序表与链表
数据结构·链表
一个响当当的名号7 小时前
B树,B+树,B*树(无代码)
数据结构·b树
古译汉书9 小时前
嵌入式铁头山羊stm32-ADC实现定时器触发的注入序列的单通道转换-Day26
开发语言·数据结构·stm32·单片机·嵌入式硬件·算法
野犬寒鸦9 小时前
力扣hot100:相交链表与反转链表详细思路讲解(160,206)
java·数据结构·后端·算法·leetcode
你是人间五月天9 小时前
sentinel实现控制台与nacos数据双向绑定
windows·sentinel
GalaxyPokemon10 小时前
LeetCode - 1089. 复写零
数据结构
失散1310 小时前
分布式专题——1.2 Redis7核心数据结构
java·数据结构·redis·分布式·架构
zzzsde11 小时前
【数据结构】强化训练:从基础到入门到进阶(1)
数据结构