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);
//    }

}
相关推荐
不做超级小白6 分钟前
一行命令修复 WSL 中 VS Code 报 `Exec format error`
windows
꧁细听勿语情꧂41 分钟前
向下调整算法,top - k 问题,链式结构二叉树,前中后序遍历
c语言·开发语言·数据结构·算法
CyrusCJA1 小时前
在Windows系统上将Redis注册为系统服务使其实现开机自启
数据库·windows·redis·缓存
如君愿1 小时前
考研复习 Day 22 | 数据结构与算法--排序(下)
数据结构·考研·排序算法·记录考研
LG.YDX1 小时前
笔试训练48天:最长无重复子数组
数据结构·算法
SHARK_pssm2 小时前
【数据结构——顺序表】
c语言·数据结构·经验分享·笔记
gumichef2 小时前
*链表OJ
数据结构·链表
如君愿2 小时前
考研复习 Day 21 | 数据结构与算法--排序(上)
数据结构·考研·排序算法·记录考研
hnjzsyjyj3 小时前
全排列问题DFS实现执行示意图
数据结构·dfs
星辰徐哥3 小时前
OpenCV入门:Windows系统下OpenCV的安装与环境配置
人工智能·windows·opencv