Java容器常用方法

1. List

java 复制代码
List<E> = new ArrayList<>();
List<E> = new LinkedList<>();
// 增删改查方法
public void add(Object element) //增添元素
public void add(int index,Object element) //在指定位置增添元素
public boolean remove(Object o) //删除指定对象
public Object remove(int index) //删除指定位置的元素
public Object set(int index,Object element) //修改指定位置元素的值
public Object get(int index) //获取指定位置元素
public int indexOf(Object o) //获取指定元素的位置
public boolean contains(Object o) //判断指定元素是否存在
 
// 其他常用方法
public int size() //获取容器中元素个数
public Iterator<E> iterator() //获取迭代器
public void clear() //清空元素

ArrayList适合快速查找元素,LinkedList适合频繁地对列表进行增加或删除元素操作,因此LinkedList类可用于实现堆栈和队列,对此LinkedList类中定义了特定的方法,如下:

java 复制代码
//栈操作
LinkedList<E> list = new LinkedList<>();
public void push(E e) //等价于addFirst()
public E pop() //等价于removeFirst()
public boolean isEmpty() //判断链表是否为空
//队列操作
Queue<E > queue = new LinkedList<>(); || LinkedList<T> list = new LinkedList<>();
public boolean offer(E e) //等价于addLast()
public E peek() //等价于getFirst()
public E poll() //等价于removeFirst()
public boolean isEmpty() //判断链表是否为空

2. Set

java 复制代码
Set<T> st = new HashSet<>();
//增删查方法
public void add(Object element) //增添元素
public boolean remove(object element) //删除元素
public boolean contains(Object o) //判断元素是否存在
// Set的contains和List的Contains的区别:
// HashSet的contains返回true,当且仅当equals返回true并且hashCode返回相等的值
// list.contains(o),等价于list中所有元素调用equals结果的或运算
 
//其他常用方法
public int size() //获取容器中元素个数
public boolean isEmpty() //判断集合是否为空
public Iterator<E> iterator() //获取迭代器
public void clear() //清空元素

3. Map

java 复制代码
Map<K, V> mp = new HashMap<>();
//增删查
public Object put(Object key,Object value) //增添元素
public Object remove(Object key) //删除元素,并返回键对应的值
public Object get(Object key) //获取键对应的值
public Object getOrDefault(Object key, Object defaultValue) //获取键对应的值,没有键,则返回默认值
public boolean containsKey(Object key) //判断指定键是否存在
public boolean containsValue(Object value) //判断指定值是否存在
 
//获取键、值、元素集合
public Collection values() //获取值集合
public Set KeySet() //获取键集合
public Set entrySet() //获取元素集合
 
//其他方法
public int size() //获取容器中元素个数
public boolean isEmpty() //判断容器是否为空
public void clear() //清空元素

4. ArrayDeque

java 复制代码
ArrayDeque<E> deque = new ArrayDeque<>();

// 基本方法
public void addFirst(E e) // 在数组前面添加元素
public void addLast(E e) // 在数组后面添加元素。
public boolean offerFirst(E e) // 在数组前面添加元素,并返回是否添加成功。
public boolean offerLast(E e) // 在数组后面添加元素,并返回是否添加成功。
public E removeFirst() // 删除第一个元素,并返回删除元素的值,如果元素为 null,则抛出异常。
public E removeLast() // 删除最后一个元素,并返回删除元素的值,如果为 null,则抛出异常。
public E pollFirst() // 删除第一个元素,并返回删除元素的值,如果元素为 null,则返回 null。
public E pollLast() // 删除最后一个元素,并返回删除元素的值,如果为 null,则返回 null。
public E getFirst() // 获取第一个元素,如果没有将抛出异常。
public E getLast() // 获取最后一个元素,如果没有将抛出异常。
public E peekFirst() // 获取最后一个元素,如果没有将返回null。
public E peekLast() // 获取最后一个元素,如果没有将返回null。
public int size() // 取队列中元素个数。
public boolean isEmpty() // 判断队列是否为空。
public void clear() // 清空
// 对列操作
public boolean offer(E e) // 在队列尾部添加一个元素,并返回是否成功。
public E peek() // 获取第一个元素,如果返回 null。
public E poll() // 删除队列中第一个元素,并返回该元素的值,如果元素为 null,则返回 null。
// 栈操作
public void push(E e) // 栈顶添加一个元素。
public E pop() // 移除栈顶元素,如果栈顶没有元素将抛出异常。 
public E peek() // 获取第一个元素,如果返回 null。

5. PriorityQueue

java 复制代码
PriorityQueue<E> pri_que = new PriorityQueue<>();
// 基本方法
public boolean add(E e) // 将指定的元素插入此优先级队列。如果队列已满,则会引发异常。
public boolean offer(E e) // 将指定的元素插入此优先级队列。如果队列已满,则返回false。

public E peek() // 获取队列顶部元素,但不删除。如果队列为空,则返回null。
public E element() // 获取队列顶部元素,但不删除。如果队列为空,则抛出异常。

public boolean remove() // 删除队列顶部元素。如果队列为空,则抛出异常。
public E poll() // 删除并返回队列顶部元素。如果队列为空,则返回null。

6. Arrays

java 复制代码
public static int binarySearch(Object[] a, Object key) //二分查找(a已排序)
public static boolean equals(Object[] a, Object[] a2) //判断两数组是否完全一致
public static void fill(Object[] a, Object val) //在a中所有位置填充val
public static void fill(Object[] a, int fromIndex, int toIndex, Object val) //在[fromIndex,toIndex)中填充元素val
public static String toString(Object[] a) //将数组a转换为字符串,如"[1, 2, 3]"
public static void sort(Object[] a) //改进的快速排序(升序)
public static void sort(Object[] a, int fromIndex, int toIndex) //对[fromIndex,toIndex)中的元素排序(升序)
public static <T> void sort(T[] a, Comparator<? super T> c) //自定义比较器排序

7. Collections

java 复制代码
// 对Collection对象
public static Object max(Collection coll) //获取最大值
public static Object min(Collection coll) //获取最小值
// 对List对象
public static int binarySearch(List list, Object key) //查找元素
public static void copy(List dest, List src) //将src复制给dest
public static void fill(List list, Object obj) //在list中填充obj
public static void reverse(List list) //列表元素倒置
public static void sort(List list) //升序排序
public static <T> void sort(List<T> list, Comparator<? super T> c) //自定义比较器排序
相关推荐
Coder_Boy_12 分钟前
基于SpringAI的在线考试系统-DDD(领域驱动设计)核心概念及落地架构全总结(含事件驱动协同逻辑)
java·人工智能·spring boot·微服务·架构·事件驱动·领域驱动
黎雁·泠崖25 分钟前
Java&C语法对比:分支与循环结构核心全解析
java·c语言
鹿角片ljp31 分钟前
Java IO流案例:使用缓冲流恢复《出师表》文章顺序
java·开发语言·windows
毕设源码-郭学长33 分钟前
【开题答辩全过程】以 广告投放管理系统为例,包含答辩的问题和答案
java
小北方城市网44 分钟前
SpringBoot 集成 RabbitMQ 实战(消息队列解耦与削峰):实现高可靠异步通信
java·spring boot·python·微服务·rabbitmq·java-rabbitmq·数据库架构
java_t_t1 小时前
Maven插件apiscan介绍与使用
java·maven·api文档·maven插件
带刺的坐椅1 小时前
FastJson2 与 SnackJson4 有什么区别?
java·jsonpath·fastjon2·snack4
linweidong1 小时前
C++如何避免 ODR(One Definition Rule)冲突?
java·jvm·c++
毅炼1 小时前
hot100打卡——day09
java·leetcode
没有bug.的程序员2 小时前
HashMap 源码深度剖析:红黑树转换机制与高并发性能陷阱
java·性能优化·并发编程·源码分析·红黑树·hashmap·技术深度