Java笔记026-集合/数组、Collection接口、ArrayList、Vector、LinkedList

news2025/2/22 22:32:48

集合

集合的理解和好处

保存多个数据使用的是数组,分析数组的弊端

数组

1、长度开始必须指定,而且一旦指定,不能更改

2、保存的必须为同一类型的元素

3、使用数组进行增加/删除元素的示意代码-比较麻烦

Person数组扩容示意代码

Person[] pers = new Person[1];//大小是1
pers[0] = new Person();
//增加新的Person对象
Person[] pers2 = new Person[pers.length + 1];//创建新数组
for(){}//拷贝pers数组的元素到pers2
pers2[pers2.length - 1] = new Person();//添加新的对象

集合

1、可以动态保存任意多个对象,使用比较方便!

2、提供了一系列方便的操作对象的方法:add、remove、set、get等

3、使用集合添加,删除新元素的示意代码-简洁

集合的框架体系

Java的集合类很多,主要分为两大类,如图:

package com14.collection_;

import java.util.ArrayList;
import java.util.HashMap;

/**
 * @author 甲柒
 * @version 1.0
 * @title Collection_
 * @package com14.collection_
 * @time 2023/1/13 17:53
 */
public class Collection_ {
    @SuppressWarnings({"all"})
    public static void main(String[] args) {
        //解读
        //1.集合主要是两组(单列集合,双列集合)
        //2.Collection接口有两个重要的子接口 List Set,他们的实现子类都是单列集合
        //3.Map接口的实现子类是双列集合,存放的 K-V
//        Collection
//        Map
        ArrayList arrayList = new ArrayList();
        arrayList.add("jack");
        arrayList.add("tom");

        HashMap hashMap = new HashMap();
        hashMap.put("NO1", "北京");
        hashMap.put("NO2", "上海");
    }
}

Collection接口和常用方法

Collection接口实现类的特点

public interface Collection<E> extends lterable<E>

1、Collection实现子类可以存放多个元素,每个元素可以是Object

2、有些Collection的实现类,可以存放重复的元素,有些不可以

3、有些Collection的实现类,有些是有序的(List),有些不是有序(Set)

4、Collection接口没有直接的实现子类,是通过它的子接口Set和List来实现的

Collection接口和常用方法

1、add //添加单个元素

2、remove //删除指定元素

3、contains //查找元素是否存在

4、size //获取元素个数

5、isEmpty //判断是否为空

6、clear //清空

7、addAll //添加多个元素

8、containsAll //查找多个元素是否都存在

9、removeAll //删除多个元素

10、说明:以ArrayList实现类来演示

package com14.collection_;

import java.util.ArrayList;

/**
 * @author 甲柒
 * @version 1.0
 * @title CollectionMethod
 * @package com14.collection_
 * @time 2023/1/13 18:42
 */
public class CollectionMethod {
    @SuppressWarnings({"all"})
    public static void main(String[] args) {
        ArrayList arrayList = new ArrayList();
        //1、add //添加单个元素
        arrayList.add("jack");
        arrayList.add(10);
        arrayList.add(true);
        System.out.println("arrayList=" + arrayList);
        //2、remove //删除指定元素
//        arrayList.remove(0);//删除第一个元素
        arrayList.remove(true);//指定删除某个元素
        System.out.println("arrayList=" + arrayList);
        //3、contains //查找元素是否存在
        System.out.println(arrayList.contains("jack"));//true
        //4、size //获取元素个数
        System.out.println(arrayList.size());//2
        //5、isEmpty //判断是否为空
        System.out.println(arrayList.isEmpty());//false
        //6、clear //清空
        arrayList.clear();
        System.out.println("arrayList=" + arrayList);
        //7、addAll //添加多个元素
        ArrayList arrayList1 = new ArrayList();
        arrayList1.add("西游记");
        arrayList1.add("三国演义");
        arrayList.addAll(arrayList1);
        System.out.println("arrayList=" + arrayList);
        //8、containsAll //查找多个元素是否都存在
        System.out.println(arrayList.containsAll(arrayList1));//true
        //9、removeAll //删除多个元素
        arrayList.add("鬼吹灯");
        arrayList.removeAll(arrayList1);
        System.out.println("arrayList=" + arrayList);//鬼吹灯
        //10、说明:以ArrayList实现类来演示
    }
}

Collection接口遍历元素方式1-使用Iterator(迭代器)

基本介绍

1、Iterator对象称为迭代器,主要用于遍历Collection集合中的元素。

2、所有实现了Collection接口的集合类都有一个iterator()方法,用以返回一个实现了lterator接口的对象,即可以返回一个迭代器。

3、Iterator的结构。[图:]

4、Iterator仅用于遍历集合,Iterator本身并不存放对象。

迭代器的执行原理

Iterator iterator = coll.iterator();//得到一个集合的迭代器

//hasNext():判断是否还有下一个元素

while(iterator.hasNext()){

//next()作用:1.指针下移2.将下移以后集合位置上的元素返回

System.out.println(iterator.next());

}

Iterator接口的方法

注意:在调用iterator.next()方法之前必须要调用iterator.hasNext()进行检测。若不调用,且下一条记录无效,直接调用itterator.next()会抛出NoSuchElementException异常

package com14.collection_;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;

/**
 * @author 甲柒
 * @version 1.0
 * @title CollectionIterator
 * @package com14.collection_
 * @time 2023/1/28 17:44
 */
public class CollectionIterator {
    @SuppressWarnings({"all"})
    public static void main(String[] args) {
        Collection collection = new ArrayList();
        collection.add(new Book("三国演义", "罗贯中", 49.9));
        collection.add(new Book("三体", "刘慈欣", 139.9));
        collection.add(new Book("流浪地球", "刘慈欣", 69.9));

//        System.out.println("collection=" + collection);
        //现在希望能够遍历collection集合
        //1.先得到collection对应的迭代器
        Iterator iterator = collection.iterator();
        //2.使用while循环遍历
//        while (iterator.hasNext()) {//判断是否还有数据
//            //返回下一个元素,类型是Objext
//            Object obj = iterator.next();
//            System.out.println("obj=" + obj);
//        }
        //快捷键 快速生成while => itit
        //显示所有快捷键的快捷键 ctrl + j
        while (iterator.hasNext()) {
            Object next = iterator.next();
            System.out.println(next);
        }
        //3.当退出while循环后,这时iterator迭代器,指向最后的元素
//        iterator.next();//NoSuchElementException
        //4.如果希望再次遍历,需要重置迭代器
        iterator = collection.iterator();
        System.out.println("=====第2次遍历=====");
        while (iterator.hasNext()) {
            Object next = iterator.next();
            System.out.println(next);
        }
    }
}

class Book {
    private String name;
    private String author;
    private double price;

    public Book(String name, String author, double price) {
        this.name = name;
        this.author = author;
        this.price = price;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getAuthor() {
        return author;
    }

    public void setAuthor(String author) {
        this.author = author;
    }

    public double getPrice() {
        return price;
    }

    public void setPrice(double price) {
        this.price = price;
    }

    @Override
    public String toString() {
        return "Book{" +
                "name='" + name + '\'' +
                ", author='" + author + '\'' +
                ", price=" + price +
                '}';
    }
}

Collection接口遍历对象方式2-for循环增强

增强for循环,可以代替iterator迭代器,特点:增强for就是简化版的iterator,本质一样 。只能用于遍历集合或数组。

基本语法

for(元素类型 元素名:集合名或数组名){
    访问元素
}

案例演示

package com14.collection_;

import java.util.ArrayList;
import java.util.Collection;

/**
 * @author 甲柒
 * @version 1.0
 * @title CollectionFor
 * @package com14.collection_
 * @time 2023/1/28 18:11
 */
public class CollectionFor {
    @SuppressWarnings({"all"})
    public static void main(String[] args) {
        Collection collection = new ArrayList();
        collection.add(new Book("三国演义", "罗贯中", 49.9));
        collection.add(new Book("三体", "刘慈欣", 139.9));
        collection.add(new Book("流浪地球", "刘慈欣", 69.9));

        //解读
        //1.使用增强for,在Collection集合
        //2.增强for,底层仍然是迭代器
        //3.增强for,可以理解成就是简化版的 迭代器遍历
        for (Object book :
                collection) {
            System.out.println(book);
        }
        //增强for,也可以直接在数组使用
//        int[] nums = {1, 8, 10, 99};
//        for (int i : nums) {
//            System.out.println("i=" + i);
//        }
    }
}

练习题

请编写程序

1、创建3个 Dog {name, age} 对象,放入到 ArrayList中,赋给List 引用

2、用迭代器和增强for循环两种方式来遍历

3、重写Dog的toString方法,输出name和age

package com14.collection_;

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

/**
 * @author 甲柒
 * @version 1.0
 * @title CollectionExercise
 * @package com14.collection_
 * @time 2023/1/28 18:21
 */
public class CollectionExercise {
    @SuppressWarnings({"all"})
    public static void main(String[] args) {
        List list = new ArrayList();
        list.add(new Dog("大黄", 5));
        list.add(new Dog("大白", 10));
        list.add(new Dog("大黑", 3));

        //先使用for增强
        for (Object dog : list) {
            System.out.println("dog=" + dog);
        }

        //使用迭代器
        System.out.println("=======使用迭代器=======");
        Iterator iterator = list.iterator();
        while (iterator.hasNext()) {
            Object dog = iterator.next();
            System.out.println("dog=" + dog);
        }
    }
}

/**
 * 1、创建3个 Dog {name, age} 对象,放入到 ArrayList中,赋给List 引用
 * 2、用迭代器和增强for循环两种方式来遍历
 * 3、重写Dog的toString方法,输出name和age
 */
class Dog {
    private String name;
    private int age;

    public Dog(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "Dog{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}

List接口和常用方法

List接口基本介绍

List接口是Collection接口的子接口

  1. List集合类中的元素有序(即添加顺序和取出顺序一致)、且可重复

  1. List集合中的每个元素都有其对应的顺序索引,即支持索引

  1. List容器中的元素都对应一个整数类型的序号记载其在容器中的位置,可以根据序号存取容器中的元素

  1. JDK API中List接口的实现类有:

package com14.list_;

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

/**
 * @author 甲柒
 * @version 1.0
 * @title List_
 * @package com14.list_
 * @time 2023/2/20 9:34
 */
public class List_ {
    public static void main(String[] args) {
        //1.List集合类中元素有序(即添加顺序和取出顺序一致)、且可重复
        List list = new ArrayList();
        list.add("tom");
        list.add("jack");
        list.add("marry");
        list.add("lsp");
        list.add("lsp");
        System.out.println("list" + list);
        //2.List集合中的每个元素都有其对应的顺序索引,即支持索引
        System.out.println(list.get(2));
    }
}

List接口的常用方法

List集合里添加了一些根据索引来操作集合元素的方法

  1. void add(int index, Object ele):在index位置插入ele元素

  1. boolean addAll(int index, Collection eles):从index位置开始将eles中的所有元素添加进来

  1. Object get(int index):获取指定index位置的元素

  1. int indexOf(Object obj):返回obj在集合中首次出现的位置

  1. int lastIndexOf(Object obj):返回obj在当前集合中末次出现的位置

  1. Object remove(int index):移除指定index位置的元素,并返回此元素

  1. Object set(int index, Object ele):设置指定index位置的元素为ele,相当于是替换

  1. List subList(int fromIndex, int toIndex):返回从fromIndex到toIndex位置的子集合

package com14.list_;

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

/**
 * @author 甲柒
 * @version 1.0
 * @title ListMethod
 * @package com14.list_
 * @time 2023/2/20 10:36
 */
public class ListMethod {
    @SuppressWarnings({"all"})
    public static void main(String[] args) {
        List list = new ArrayList();
        list.add("渣渣辉");
        list.add("唐玄奘");
//        void add(int index, Object ele):在index位置插入ele元素
        //在index = 1的位置插入一个对象
        list.add(1, "甲柒");
        System.out.println("list=" + list);
//        boolean addAll(int index, Collection eles):从index位置开始将eles中的所有元素添加进来
        List list2 = new ArrayList();
        list2.add("jack");
        list2.add("tom");
        list.addAll(1, list2);
        System.out.println("list=" + list);
//        Object get(int index):获取指定index位置的元素
        System.out.println(list.get(2));
//        int indexOf(Object obj):返回obj在集合中首次出现的位置
        System.out.println(list.indexOf("tom"));
//        int lastIndexOf(Object obj):返回obj在当前集合中末次出现的位置
        list.add("甲柒");
        System.out.println("list=" + list);
        System.out.println(list.lastIndexOf("甲柒"));
//        Object remove(int index):移除指定index位置的元素,并返回此元素
        list.remove(0);
        System.out.println("list=" + list);
//        Object set(int index, Object ele):设置指定index位置的元素为ele,相当于是替换
        list.set(1, "沈腾");
        System.out.println("list=" + list);
//        List subList(int fromIndex, int toIndex):返回从fromIndex到toIndex位置的子集合
        List list1 = list.subList(0, 2);
        System.out.println("list1=" + list1);
    }
}

List接口练习题1

添加10个以上的元素(比如String "hello"),在2号位插入一个元素"甲柒",获得第5个元素,删除第6个元素,修改第7个元素,在使用迭代器遍历集合,要求:使用List的实现类ArrayList完成。

package com14.list_;

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

/**
 * @author 甲柒
 * @version 1.0
 * @title ListExercise
 * @package com14.list_
 * @time 2023/2/20 18:55
 */
public class ListExercise {
    //    添加10个以上的元素(比如String "hello"),
//    在2号位插入一个元素"甲柒",获得第5个元素,
//    删除第6个元素,修改第7个元素,在使用迭代器遍历集合,
//    要求:使用List的实现类ArrayList完成。
    @SuppressWarnings({"all"})
    public static void main(String[] args) {
        List list = new ArrayList();
        for (int i = 0; i < 12; i++) {
            list.add("hello" + i);
        }
        System.out.println("List=" + list);
//        在2号位插入一个元素"甲柒"
        list.add(1, "甲柒");
        System.out.println("List=" + list);
//        获得第5个元素,
        System.out.println("第五个元素=" + list.get(4));
//        删除第6个元素
        list.remove(5);
        System.out.println("List=" + list);
//        修改第7个元素
        list.set(6, "java");
        System.out.println("List=" + list);
//        在使用迭代器遍历集合
        Iterator iterator = list.iterator();
        while (iterator.hasNext()) {
            Object next = iterator.next();
            System.out.println("next=" + next);
        }
    }
}

List三种遍历方式[ArrayList、Linked、Vector]

package com14.list_;

import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;

/**
 * @author 甲柒
 * @version 1.0
 * @title ListFor
 * @package com14.list_
 * @time 2023/2/20 19:12
 */
public class ListFor {
    @SuppressWarnings({"all"})
    public static void main(String[] args) {
//        List 接口的实现子类  LinkedList
//        List list = new ArrayList();
//        List list = new Vector();
        List list = new LinkedList();
        list.add("蟹老板");
        list.add("章鱼哥");
        list.add("海绵宝宝");
        list.add("派大星");
        //遍历
        //1.迭代器
        System.out.println("==========迭代器==========");
        Iterator iterator = list.iterator();
        while (iterator.hasNext()) {
            Object next = iterator.next();
            System.out.println(next);
        }
        System.out.println("==========增强for==========");
        //2.增强for
        for (Object o : list) {
            System.out.println(o);
        }
        System.out.println("==========普通for==========");
        //3.普通for
        for (int i = 0; i < list.size(); i++) {
            System.out.println(list.get(i));
        }
    }
}

List接口练习题2

使用List的实现类添加三本书,并遍历,打印效果如下

要求:

  1. 按价格排序,从低到高(使用冒泡排序)

  1. 使用ArrayList、LinkedList、Vector三种集合实现

package com14.list_;

import java.util.LinkedList;
import java.util.List;

/**
 * @author 甲柒
 * @version 1.0
 * @title ListExercise02
 * @package com14.list_
 * @time 2023/2/20 19:30
 */
@SuppressWarnings({"all"})
public class ListExercise02 {

    public static void main(String[] args) {
//        List list = new ArrayList();
        List list = new LinkedList();
//        List list = new Vector();
        list.add(new Book("红楼梦", 39, "曹雪芹"));
        list.add(new Book("西游记", 100, "吴承恩"));
        list.add(new Book("水浒传", 9.9, "施耐庵"));
        list.add(new Book("三国演义", 88, "罗贯中"));
//        list.add(new Book("红楼梦","39","曹雪芹"));
        //遍历
        for (Object o : list) {
            System.out.println(o);
        }
        //冒泡排序
        sort(list);
        System.out.println("===排序后===");
        //遍历
        for (Object o : list) {
            System.out.println(o);
        }
    }

    //静态方法
    public static void sort(List list) {
        int listSize = list.size();
        for (int i = 0; i < listSize - 1; i++) {
            for (int j = 0; j < listSize - 1 - i; j++) {
                //取出对象Book
                Book book1 = (Book) list.get(j);
                Book book2 = (Book) list.get(j + 1);
                if (book1.getPrice() > book2.getPrice()) {
                    list.set(j, book2);
                    list.set(j + 1, book1);
                }
            }
        }
    }
}

ArryList的注意事项

  1. permits all elements,including null,ArrayList可以加入null,并且多个

  1. ArrayList是由数组来实现数据存储的

  1. ArrayList基本等同于Vector,除了ArrayList是线程不安全(执行效率高),在多线程情况下,不建议使用ArrayList

package com14.list_;

import java.util.ArrayList;

/**
 * @author 甲柒
 * @version 1.0
 * @title ArrayListDetail
 * @package com14.list_
 * @time 2023/2/21 19:46
 */
@SuppressWarnings({"all"})
public class ArrayListDetail {
    public static void main(String[] args) {
        //ArrayList是线程不安全的,源码中没有synchronized
        /*
         public boolean add(E e) {
         ensureCapacityInternal(size + 1);  // Increments modCount!!
         elementData[size++] = e;
         return true;
         }
         */
        ArrayList arrayList = new ArrayList();
        arrayList.add(null);
        arrayList.add("jack");
        arrayList.add(null);
        System.out.println(arrayList);
    }
}

ArrayList底层结构和源码分析

ArrayList的底层操作机制源码分析

1、ArrayList中维护了一个Object类型的数组elementData

transient Object[] elementData;//transient表示瞬间,短暂的,表示该属性不会被序列号

2、当创建ArrayList对象时,如果使用的是无参构造器,则初始elementData容量为0,第1次添加,则扩容elementData为10,如需再次扩容,则扩容elementData为1.5倍

3、如果使用的是指定大小的构造器,则初始elementData容量为指定大小,如需要扩容,则直接扩容elementData为1.5倍

package com14.list_;

import java.util.ArrayList;

/**
 * @author 甲柒
 * @version 1.0
 * @title ArrayListSource
 * @package com14.list_
 * @time 2023/2/21 21:41
 */
@SuppressWarnings({"all"})
public class ArrayListSource {
    public static void main(String[] args) {

        //解读
        //使用无参构造器创建ArrayList对象
        ArrayList list = new ArrayList();
        //ArrayList list = new ArrayList(8);
        //使用for给list集合添加1-10数据
        for (int i = 1; i <= 10; i++) {
            list.add(i);
        }
        //使用for给list集合添加11-15数据
        for (int i = 11; i <= 15; i++) {
            list.add(i);
        }
        list.add(100);
        list.add(200);
        list.add(null);
    }
}

Vector底层结构和源码剖析

Vector的基本介绍

1、Vector类的定义说明

2、Vector底层也是一个对象数组,protected Object[] elementData

3、Vector是线程同步的,即线程安全,Vector类的操作方法带有synchronized

4、在开发中,需要线程同步安全时,考虑使用Vector

Vector底层结构和ArrayList的比较

Vector和ArrayList的比较

LinkedList底层结构

LiskedList的全面说明

  1. LiskedList底层实现了双向链表和双端队列特点

  1. 可以添加任意元素(元素可以重复),包括null

  1. 线程不安全,没有实现同步

LiskedList的底层操作机制

  1. LinkedList底层维护了一个双向链表

  1. LinkedList中维护了两个属性first和last分别指向首节点和尾节点

  1. 每个节点(Node对象),里又维护了prev、next、item三个属性,其中通过prev指向前一个节点,通过next指向后一个节点,最终实现双链表

  1. 所以LinkedList的元素的添加和删除,不是通过数组完成的,相对来说效率较高

  1. 模拟一个简单的双链表

package com14.list_;

/**
 * @author 甲柒
 * @version 1.0
 * @title LinkedList
 * @package com14.list_
 * @time 2023/2/21 22:55
 */
public class LinkedList {
    public static void main(String[] args) {
        //模拟一个简单的双向链表

        Node jack = new Node("jack");
        Node tom = new Node("tom");
        Node jerry = new Node("jerry");

        //连接三个结点,形成双向链表
        //jack -> tom -> jerry
        jack.next = tom;
        tom.next = jerry;
        //jerry -> tom -> jack
        jerry.pre = tom;
        tom.pre = jack;

        Node first = jack;//让first引用指向jack,就是双向链表的头结点
        Node last = jerry;//让last引用指向hsp,就是双向链表的尾结点

        //演示,从头到尾进行遍历
        System.out.println("===从头到尾进行遍历===");
        while (true) {
            if (first == null) {
                break;
            }
            //输出first 信息
            System.out.println(first);
            first = first.next;
        }

        //演示,从尾到头的遍历
        System.out.println("====从尾到头的遍历====");
        while (true) {
            if (last == null) {
                break;
            }
            //输出last 信息
            System.out.println(last);
            last = last.pre;
        }

        //演示链表的添加对象/数据,是多么的方便
        //要求,是在 tom --------- 老韩直接,插入一个对象 smith

        //1. 先创建一个 Node 结点,name 就是 smith
        Node smith = new Node("smith");
        //下面就把 smith 加入到双向链表了
        smith.next = jerry;
        smith.pre = tom;
        jerry.pre = smith;
        tom.next = smith;

        //让first 再次指向jack
        first = jack;//让first引用指向jack,就是双向链表的头结点

        System.out.println("===从头到尾进行遍历===");
        while (true) {
            if (first == null) {
                break;
            }
            //输出first 信息
            System.out.println(first);
            first = first.next;
        }

        last = jerry; //让last 重新指向最后一个结点
        //演示,从尾到头的遍历
        System.out.println("====从尾到头的遍历====");
        while (true) {
            if (last == null) {
                break;
            }
            //输出last 信息
            System.out.println(last);
            last = last.pre;
        }

    }
}

//定义一个Node 类,Node 对象 表示双向链表的一个结点
class Node {
    public Object item; //真正存放数据
    public Node next; //指向后一个结点
    public Node pre; //指向前一个结点

    public Node(Object name) {
        this.item = name;
    }

    public String toString() {
        return "Node name=" + item;
    }
}

LinkedList的增删改查案例

package com14.list_;

import java.util.Iterator;
import java.util.LinkedList;

/**
 * @author 甲柒
 * @version 1.0
 * @title LInkedListCRUD
 * @package com14.list_
 * @time 2023/2/22 20:22
 */
@SuppressWarnings({"all"})
public class LInkedListCRUD {
    public static void main(String[] args) {

        LinkedList linkedList = new LinkedList();
        linkedList.add(1);
        linkedList.add(2);
        linkedList.add(3);
        System.out.println("linkedList=" + linkedList);

        //演示一个删除结点的
        linkedList.remove(); // 这里默认删除的是第一个结点
        //linkedList.remove(2);

        System.out.println("linkedList=" + linkedList);

        //修改某个结点对象
        linkedList.set(1, 999);
        System.out.println("linkedList=" + linkedList);

        //得到某个结点对象
        //get(1) 是得到双向链表的第二个对象
        Object o = linkedList.get(1);
        System.out.println(o);//999

        //因为LinkedList 是 实现了List接口, 遍历方式
        System.out.println("===LinkedList遍历迭代器====");
        Iterator iterator = linkedList.iterator();
        while (iterator.hasNext()) {
            Object next = iterator.next();
            System.out.println("next=" + next);

        }

        System.out.println("===LinkedList遍历增强for====");
        for (Object o1 : linkedList) {
            System.out.println("o1=" + o1);
        }
        System.out.println("===LinkedList遍历普通for====");
        for (int i = 0; i < linkedList.size(); i++) {
            System.out.println(linkedList.get(i));
        }


        //源码阅读.
        /* 1. LinkedList linkedList = new LinkedList();
              public LinkedList() {}
           2. 这时 linkedList 的属性 first = null  last = null
           3. 执行 添加
               public boolean add(E e) {
                    linkLast(e);
                    return true;
                }
            4.将新的结点,加入到双向链表的最后
             void linkLast(E e) {
                final Node<E> l = last;
                final Node<E> newNode = new Node<>(l, e, null);
                last = newNode;
                if (l == null)
                    first = newNode;
                else
                    l.next = newNode;
                size++;
                modCount++;
            }

         */

        /*
          读源码 linkedList.remove(); // 这里默认删除的是第一个结点
          1. 执行 removeFirst
            public E remove() {
                return removeFirst();
            }
         2. 执行
            public E removeFirst() {
                final Node<E> f = first;
                if (f == null)
                    throw new NoSuchElementException();
                return unlinkFirst(f);
            }
          3. 执行 unlinkFirst, 将 f 指向的双向链表的第一个结点拿掉
            private E unlinkFirst(Node<E> f) {
                // assert f == first && f != null;
                final E element = f.item;
                final Node<E> next = f.next;
                f.item = null;
                f.next = null; // help GC
                first = next;
                if (next == null)
                    last = null;
                else
                    next.prev = null;
                size--;
                modCount++;
                return element;
            }
         */
    }
}

ArrayList和LinkedList比较

ArrayList和LinkedList比较

如何选择ArrayList和LinkedList:

  1. 如果改查的操作多,选择ArrayList

  1. 如果增删的操作多,选择LinkedList

  1. 一般来说,在程序中,80%~90%都是查询,因此大部分情况下会选择ArrayList

  1. 在一个项目中,根据业务灵活选择,也可以这样,一个模块使用的是ArrayList,另一个模块是LinkedList

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/364098.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ChatGPT三个关键技术

情景学习&#xff08;In-context learning&#xff09; 对于一些LLM没有见过的新任务&#xff0c;只需要设计一些任务的语言描述&#xff0c;并给出几个任务实例&#xff0c;作为模型的输入&#xff0c;即可让模型从给定的情景中学习新任务并给出满意的回答结果。这种训练方式能…

论文笔记:How transferable are features in deep neural networks? 2014年NIP文章

文章目录一、背景介绍二、方法介绍三、实验论证四、结论五、感想参考文献一、背景介绍 1.问题介绍&#xff1a; 许多在自然图像上训练的深度神经网络都表现出一个奇怪的共同现象&#xff1a;在第一层&#xff0c;它们学习类似于Gabor过滤器和color blobs的特征。这样的第一层特…

c++提高篇——list容器

一、基本概念 功能:将数据进行链式存储 链表&#xff08;(list)是一种物理存储单元上非连续的存储结构&#xff0c;数据元素的逻辑顺序是通过链表中的指针链接实现的&#xff0c;链表由一系列结点组成。 结点的组成:一个是存储数据元素的数据域&#xff0c;另一个是存储下一个…

3DVR营销是什么?是否成为市场热门?

在当今市场经济环境中&#xff0c;营销对于在企业发展中的作用至关重要。市场是企业发展的战场&#xff0c;谁能在市场营销方面做得更好&#xff0c;就能够吸引公域平台流量、占据主流市场、开拓新局面从而稳定现有规模。这将确保企业不被市场淘汰&#xff0c;而是能够可持续性…

CSS(配合html的网页编程)

续上一篇博客,CSS是前端三大将中其中的一位,主要负责前端的皮,也就是负责html的装饰.一、基本语法规则也就是:选择器若干属性声明(选中一个元素然然后进行属性声明)CSS代码是放在style标签中,它可以放在head中也可以放在body中 ,可以放到代码的任意位置.color也就是设置想要输入…

如何描述元素与元素间的逻辑关系?

逻辑结构反映的是数据元素之间的关系&#xff0c;它们与数据元素在计算机中的存储位置无关&#xff0c;是数据结构在用户面前所呈现的形式。根据不同的逻辑结构来分&#xff0c;数据结构可分为集合、线性结构、树形结构和图形结构4种形式&#xff0c;接下来分别进行简要介绍。 …

宝塔搭建实战php源码云切程序转码m3u8生程序开源源码

大家好啊&#xff0c;我是测评君&#xff0c;欢迎来到web测评。 今天给大家分享一套php云切片转码的源码&#xff0c;分享自己的视频但是由于视频文件太大&#xff0c;服务器带宽太小&#xff0c;导致分享困难&#xff0c;部署这套系统后&#xff0c;就可以在上传视频后切成ts格…

车机开发—【CarService启动流程】

汽车架构&#xff1a;车载HAL是汽车与车辆网络服务之间的接口定义&#xff08;同时保护传入的数据&#xff09;&#xff1a; 车载HAL与Android Automotive架构&#xff1a; Car App&#xff1a;包括OEM和第三方开发的AppCar API&#xff1a;内有包含CarSensorManager在内的AP…

5个有效的华为(HUAWEI)手机数据恢复方法

5个有效的手机数据恢复方法 华为智能手机中的数据丢失比许多人认为的更为普遍。发生这种类型的丢失有多种不同的原因&#xff0c;因此数据恢复软件的重要性。您永远不知道您的智能手机何时会在这方面垮台&#xff1b;因此&#xff0c;预防总比哀叹好&#xff0c;这就是为什么众…

通过 FTP 使用 Python 自动压缩网站图像

图像压缩对于技术SEO世界来说并不陌生,但是随着核心生命体征形式的网站性能是一个排名因素,现在是时候开始采取行动了。我已经做了几十次网站审计,我发现 80% 的网站性能问题都可以在图像或 JavaScript 下进行。当我看到图像是一个大问题时,我会欢呼,因为它是最容易解决的…

注意啦,面试通过后,别忘了教师资格证认定

所有要「教师资格证认定」教程的宝子们看过来面试合格的小伙伴都可以进行认定工作 . 认定时间 查询各省份认定公告&#xff0c;确定认定时间范围。以下是公告汇总网址&#xff08;https://www.jszg.edu.cn/portal/qualification_cert/dynamics?id21691&#xff09; 认定次数 每…

【jQuery】js实现文件浏览功能

1.说明 近期遇到一个浏览用户文件的需求&#xff0c;类似于访问百度网盘那样的列表&#xff0c;包含文件和文件夹&#xff0c;这个功能实现起来很简单&#xff0c;从服务器获取到的文件列表至少要有文件id、父级文件id、是否文件夹这三个字段 2.html设计 前端排版看你实际情…

x86架构设备的OpenWrt的空间扩容问题

openwrt固件是squashfs-combined-efi非exf4格式 直接将原有根分区扩容 用插件是&#xff1a;fdisk,losetup,resize2fs,blkid df -h fdisk -l fdisk /dev/sda //进入fdisk分区管理工具注意fdisk后参数是磁盘名称&#xff0c;是要根据实际情况填写 fdisk /dev/sda //进入fdi…

【04-JVM面试专题-什么是双亲委派机制(父类委托机制)?如何打破双亲委派机制?双亲委派机制的优缺点?什么是沙箱安全机制呢?】

什么是双亲委派机制&#xff1f;如何打破双亲委派机制&#xff1f; JVM的双亲委派机制知道吗&#xff1f;怎么打破它呢&#xff1f;你看看自己掌握的怎么样呢&#xff1f; 什么是双亲委派机制&#xff1f;(父类委托机制) 检查某个类是否已经加载 自底向上&#xff0c;从Custom…

将数组中的每个元素四舍五入到指定的精度numpy.rint()

【小白从小学Python、C、Java】 【计算机等级考试500强双证书】 【Python-数据分析】 将数组中的每个元素 四舍五入到指定的精度 numpy.rint() 选择题 请问np.rint(a)的输出结果是? import numpy as np anp.array([-1.72,-1.3,0.37,2.4]) print("【显示】a&#xff1a;\n…

requests库基本用法

目录 1 GET请求 1.1 无参数 1.2 查询字符串 2 POST 2.1 无参数 2.2 json数据 2.3 文件 3 一些常见的请求 3.1 base64 requests是请求用的&#xff0c;在发起请求中requests会默认帮我们解决一些问题&#xff0c;比如跨域 下面做几个例子&#xff0c;服务选用…

CTFer成长之路之SSRF漏洞

SSRF漏洞CTF SSRF Training 题目描述: web容器中存在一个flag&#xff0c;mysql中存在一个管理员账号密码&#xff0c;其余容器中均没有特定flag mysql容器中内置 tcpdump vulnweb容器中内置一个 fpm.py 攻击脚本 docker-compose.yml version: "3" services:w…

有色金属行业数字化之路探析

有色金属行业是我国国民经济的支柱产业和重要组成部分&#xff0c;是处于整个原材料生产链的上游环节&#xff0c;其支撑着冶炼、钢铁、智能制造业、芯片、建筑等行业的发展&#xff0c;也是是科学研究、国防建设等方面发展的重要材料基础&#xff0c;同时还是保障国家综合实力…

Linux之安装node

Linux之安装node步骤如下 1.去网站下载node 下载地址&#xff1a; https://npm.taobao.org/mirrors/ 2.上传到指定目录下 3.解压 tar -zxvf node-v17.3.0-linux-x644.配置node环境变量 //执行以下命令 vim /etc/profile //在path中加入以下内容 /usr/local/node-v15.14.0/b…

电力电子系统仿真软件--Psim仿真软件设计

目录 1.简介 2.应用优势 3.应用领域 4.电路结构 5.界面介绍 6.应用实例 6.1 主电路部分 6.2 控制电路部分 6.3 具体的电路原理及仿真搭建过程后续会一一介绍&#xff0c;请各位点赞关注&#xff0c;你的关注将是博主最大的更新动力。 7.电力系统仿真软件下载链接 1.简…