List(特有方法、遍历方式、ArrayList底层原理、LinkedList底层原理,二者区别)

List集合

java 复制代码
package com.itheima.demo7list;

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

public class ListDemo1 {
    public static void main(String[] args) {
        //目标:掌握List集合独有的功能
        List<String> list = new ArrayList<>();//一行经典代码  多态

        //添加元素
        list.add("hello");
        list.add("world");
        list.add("java");
        list.add("java");
        System.out.println(list);//[hello, world, java, java]

        //给第三个位置插入一个数据,唐三
        list.add(2,"唐三");
        System.out.println(list);//[hello, world, 唐三, java, java]

        //删除一个元素hello
        list.remove("hello");
        //list.remove(0);  //按照索引删除
        System.out.println(list);//[world, 唐三, java, java]

        //把world修改为白小纯
        list.set(0,"白小纯");
        System.out.println(list);//[白小纯, 唐三, java, java]

        //获取元素
        String s = list.get(0);
        System.out.println(s);//白小纯
    }
}
java 复制代码
        System.out.println("======================四种遍历方式============================");

        //1、for循环
        for (int i = 0; i < list.size(); i++) {
            System.out.println(list.get(i));
        }

        //2、迭代器
        Iterator<String> it = list.iterator();//创建一个迭代器对象
        while (it.hasNext()) //判断集合中是否有元素
        {
            String s1 = it.next();
            System.out.println(s1);
        }

        //3、增强for(迭代器的简化)
        for (String s2 : list) //for(集合元素类型 变量名 : 集合对象)
        {
            System.out.println(s2);
        }

        //4、Lambda表达式
        //未简化形式
//        list.forEach(new Consumer<String>() {
//            @Override
//            public void accept(String s) {
//                System.out.println(s);
//            }
//        });
        list.forEach(s3 -> System.out.println(s3));

ArrayList底层原理

是在第一次添加数据后创建数组,本来是空数组

LinkedList底层原理


双向链表每个节点包括上一个节点地址和下一个节点地址

LinkedList应用场景

1、

java 复制代码
package com.itheima.demo7list;

import java.util.LinkedList;

public class ListDemo2 {
    public static void main(String[] args) {
        //目标:用LinkedList做一个队列对象
        LinkedList<String> queue = new LinkedList<>();//LinkedList的独有功能不能用多态

        //入队
        queue.addLast("凯撒");
        queue.addLast("楚子航");
        queue.addLast("诺诺");
        queue.addLast("路明非");
        System.out.println(queue);//[凯撒, 楚子航, 诺诺, 路明非]

        //出队
        System.out.println(queue.removeFirst());
        System.out.println(queue.removeFirst());
        System.out.println(queue);//[诺诺, 路明非]
    }
}

2、

java 复制代码
        //做一个栈
        LinkedList<String> stack = new LinkedList<>();
        //压栈
        //stack.push("林动");//也可以用push,包了addFirst的皮
        stack.addFirst("林动");
        stack.addFirst("林貂");
        stack.addFirst("林炎");
        stack.addFirst("大荒囚天指");
        stack.addFirst("紫影九动");
        System.out.println(stack);//[紫影九动, 大荒囚天指, 林炎, 林貂, 林动]

        //弹栈
        System.out.println(stack.pop());////也可以用pop,包了removeFirst的皮
        System.out.println(stack.removeFirst());
        System.out.println(stack.removeFirst());
        System.out.println(stack);//[林炎, 林貂, 林动]

LinkedList小结

增删比较少,查询比较多,用ArrayList,占内存少,用的比较多;

增删相对多,查询少,用LinkedList,比较占内容

相关推荐
星火开发设计2 小时前
this 指针:指向对象自身的隐含指针
开发语言·数据结构·c++·学习·指针·知识
毕设源码-钟学长2 小时前
【开题答辩全过程】以 基于SSM的孤儿救助信息管理系统设计与实现为例,包含答辩的问题和答案
java
独自破碎E2 小时前
【曼哈顿距离】BISHI25 最大 FST 距离
java·开发语言
苏涵.2 小时前
Java三大集合:List、Set、Map
java·开发语言
存在的五月雨2 小时前
Spring Security认证流程
java·开发语言·mysql
树码小子2 小时前
综合练习:验证码案例(1)总体设计
java·开发语言·spring
一嘴一个橘子2 小时前
idea 执行 Maven 的 `clean`、`install`、`package` 等命令报错
java
Sylvia-girl2 小时前
线程通讯~
java
二年级程序员2 小时前
一篇文章掌握“顺序表”
c语言·数据结构
Victor3562 小时前
MongoDB(2)MongoDB与传统关系型数据库的主要区别是什么?
后端