List集合详解

简介: List集合详解

为什么要学习集合呢?

数组是静态的,一个数组实例具有固定的大小,一旦创建了就无法改变容量了

集合是可以动态扩展容量,可以根据需要动态改变大小,集合提供更多的成员方法,能满足更多的需求

一.集合体系结构

a.增删改查

b.有序

c.数据可重复

package com.ctb.list;
import java.util.ArrayList;
import java.util.List;
/**
 * list集合的特点
 * 1.增删改查
 * 2.有序
 * 3.数据可重复
 * @author biao
 *
 */
public class Demo1 {
  public static void main(String[] args) {
    List list = new ArrayList<>();
    // 增加
    list.add("a");
    list.add("b");
    list.add("c");
    // 删除
    list.remove("b");
    // 修改
    list.set(0, "d");
    // 查询
    System.out.println(list);list.add("a");list.add("a");
  }
}

三.三种遍历方式

a.foreach遍历

b.for循环遍历

package com.ctb.list;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
/**
 * list集合遍历的三种方式
 * 1.foreach遍历
 * 2.for循环遍历
 * 3.iterator迭代器遍历
 * @author biao
 *
 */
public class Demo2 {
  public static void main(String[] args) {
    List list = new ArrayList<>();
    // 增加
    list.add("a");
    list.add("b");
    list.add("c");
    //1.foreach遍历
    for (Object object : list) {
      System.out.println(object);
    }
    //2.for循环遍历
    for (int i = 0; i <list.size(); i++) {
      System.out.println(list.get(i));
    }
    //3.iterator迭代器遍历
    Iterator it = list.iterator();
    while (it.hasNext()) {
      Object object = (Object) it.next();
      System.out.println(object);
    }
  }
}

四.Linkedlist与Arraylist

linkedlist对比arraylist的数据结构

linkedlist:查询修改慢,增加删除快

arraylist:查询修改快,增加删除慢

压栈操作(就是在栈中存入内容)

  //先规定栈的最大容量
    Object[] objs;
    //获取当前栈容量
    int size;
    public void SQ(int MaxLen) {
        this.objs = new Object[MaxLen];
    }
    //进行压栈操作(就是在栈中存入内容)
    public void push(Object x) {
     //先给当前指针位置赋值,然后指针变大
        System.out.println("压栈操作,压入内容为" + (objs[size++] = x)); 
   }

弹栈操作(获取栈顶数据,然后弹出栈中,栈容量减少)

  //先规定栈的最大容量
    Object[] objs;
    //获取当前栈容量
    int size;
    public void SQ(int MaxLen) {
        this.objs = new Object[MaxLen];
    }
//弹栈操作
    public void popu() {
    //获取栈顶数据,然后弹出栈中,栈容量减少
        System.out.println("弹出栈顶内容:" + objs[size - 1]);
        size--;
    }

linkedlist完成堆栈容器

removeLast():删除并返回此列表中的最后一个元素。

removeFirst():从此列表中删除并返回第一个元素。

package com.ctb.list;
import java.util.LinkedList;
/**
 * linkedlist完成堆栈容器
 * 
 * @author biao
 *
 */
public class Demo3 {
  public static void main(String[] args) {
    // LinkedList的特点:查询修改慢,增加删除快
    LinkedList list = new LinkedList<>();
    // 增加数据到集合中
    list.add("a");
    list.add("b");
    list.add("c");
    list.add("d");
    DuiZhan dz = new DuiZhan(list);
    // 调用下面xjhc的方法,后存进去的元素要先输出,先存进去的后输出,
    // 就像桶装羽毛球,先放进去的后拿出来
    System.out.println(dz.xjhc());
    System.out.println(dz.xjhc());
    System.out.println(dz.xjhc());
    // System.out.println(dz.xjhc());
    System.out.println(list);
  }
}
class DuiZhan {
  private LinkedList list;
  public DuiZhan(LinkedList list) {
    super();
    this.list = list;
  }
  // 压栈操作(就是在栈中存入内容)
  // 弹栈操作(获取栈顶数据,然后弹出栈中,栈容量减少)
  public Object xjhc() {
    return list.removeLast();
  }
}

输出结果:

五.增长因子--list调优

ArrayList的扩容因子是1.5 ,增长因子为0.5

ArrayList的容量为10,一次扩容后是容量为15

了解数组长度不可变,集合长度可变的原因

package com.ctb.list;
import java.lang.reflect.Field;
import java.util.ArrayList;
/**
 * list调优--增长因子 
 * 1+0.5增长因子为0.5,扩容因子为1.5
 * 
 * 了解数组长度不可变,集合长度可变的原因
 * 
 * @author biao
 *
 */
public class Demo4 {
  public static void main(String[] args) throws Exception {
    // ArrayList的特点:查询修改快,增加删除慢
    ArrayList list = new ArrayList<>(20);
    for (int i = 0; i <= 100; i++) {
      list.add(i);
      System.out.println("打印前" + list + "\r");
      getArrLength(list);
    }
    getArrLength(list);
  }
  // arraylist对象底层数组的长度
  private static void getArrLength(ArrayList list) throws Exception {
    Field f = list.getClass().getDeclaredField("elementData");
    f.setAccessible(true);
    System.out.println("elementData的长度是:" + ((Object[]) f.get(list)).length);
  }
}

输出结果:

六.集合框架list去重以及底层原理

a.元素去重

package com.ctb.list;
import java.util.ArrayList;
import java.util.List;
/**
 * list底层对象去重原理
 * 
 * @author biao
 *
 */
public class Demo5 {
  public static void main(String[] args) {
    List list = new ArrayList();
    list.add("a");
    list.add("f");
    list.add("c");
    System.out.println("去重前:"+list);
    if (!list.contains("b")) {
      list.add("d");
    }
    System.out.println("去重后:"+list);
  }
}

b.对象去重

在集合中对象去除重复要注意,一定要重写equals方法,否则无效

package com.ctb.list;
import java.util.ArrayList;
import java.util.List;
/**
 * list底层对象去重原理
 * 
 * @author biao
 *
 */
public class Demo5 {
  public static void main(String[] args) {
    List list = new ArrayList();
    list.add(new Cat(1, "小翔子"));
    list.add(new Cat(2, "小例子"));
    list.add(new Cat(3, "小狗子"));
    System.out.println("去重前:"+list);
    if (!list.contains(new Cat(3, "小狗子"))) {
      list.add(new Cat(3, "小狗子"));
    }
    System.out.println("去重后:"+list);
  }
}
class Cat{
  private int cid;
  private String cname;
  public Cat() {
    // TODO Auto-generated constructor stub
  }
  public int getCid() {
    return cid;
  }
  public void setCid(int cid) {
    this.cid = cid;
  }
  public String getCname() {
    return cname;
  }
  public void setCname(String cname) {
    this.cname = cname;
  }
  @Override
  public String toString() {
    return "Cat [cid=" + cid + ", cname=" + cname + "]";
  }
  public Cat(int cid, String cname) {
    super();
    this.cid = cid;
    this.cname = cname;
  }
  @Override
  public boolean equals(Object obj) {
    if (this == obj)
      return true;
    if (obj == null)
      return false;
    if (getClass() != obj.getClass())
      return false;
    Cat other = (Cat) obj;
    if (cid != other.cid)
      return false;
    if (cname == null) {
      if (other.cname != null)
        return false;
    } else if (!cname.equals(other.cname))
      return false;
    return true;
  }
}

set集合与map集合敬请下回讲解哦😉

希望大家能点点爱心与收藏哦💕💕💕


相关文章
|
4月前
|
存储 安全 Java
【Java集合类面试二十五】、有哪些线程安全的List?
线程安全的List包括Vector、Collections.SynchronizedList和CopyOnWriteArrayList,其中CopyOnWriteArrayList通过复制底层数组实现写操作,提供了最优的线程安全性能。
|
4月前
|
安全
List集合特有功能
List集合特有功能
39 2
|
4月前
|
Java
【Java集合类面试二十三】、List和Set有什么区别?
List和Set的主要区别在于List是一个有序且允许元素重复的集合,而Set是一个无序且元素不重复的集合。
|
4月前
|
存储 Java
Java学习笔记 List集合的定义、集合的遍历、迭代器的使用
Java学习笔记 List集合的定义、集合的遍历、迭代器的使用
|
2月前
|
安全 Java 程序员
深入Java集合框架:解密List的Fail-Fast与Fail-Safe机制
本文介绍了 Java 中 List 的遍历和删除操作,重点讨论了快速失败(fail-fast)和安全失败(fail-safe)机制。通过普通 for 循环、迭代器和 foreach 循环的对比,详细解释了各种方法的优缺点及适用场景,特别是在多线程环境下的表现。最后推荐了适合高并发场景的 fail-safe 容器,如 CopyOnWriteArrayList 和 ConcurrentHashMap。
64 5
|
28天前
|
NoSQL Java Redis
List集合按照由小到大排序或者由大到小排序
List集合按照由小到大排序或者由大到小排序
39 0
|
2月前
|
存储 分布式计算 NoSQL
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
29 3
|
3月前
|
NoSQL Java Redis
List集合按照由小到大排序或者由大到小排序
List集合按照由小到大排序或者由大到小排序
25 3
|
4月前
|
存储 安全 Java
java集合框架复习----(2)List
这篇文章是关于Java集合框架中List集合的详细复习,包括List的特点、常用方法、迭代器的使用,以及ArrayList、Vector和LinkedList三种实现类的比较和泛型在Java中的使用示例。
java集合框架复习----(2)List
|
4月前
|
存储 安全 Java
java集合框架复习----(4)Map、List、set
这篇文章是Java集合框架的复习总结,重点介绍了Map集合的特点和HashMap的使用,以及Collections工具类的使用示例,同时回顾了List、Set和Map集合的概念和特点,以及Collection工具类的作用。
java集合框架复习----(4)Map、List、set