【QA】Java集合常用的函数

前言

本文介绍Java集合中常用的函数。

Collection接口

通用函数 | Collections工具类

image-20231018162535633

通用函数 | List接口 + Set接口

通用函数,均与索引无关。

方法作用
public boolean add(E e)
public boolean remove(E e)
public void clean()删完
public boolean contains(Object obj)包含
public boolean isEmpty()判空
public int size()返回集合的元素数量

remove()contains()两个函数依赖对象底层的equals()方法

  • 若对象没有重写equals()方法,比较的是地址值,无法按照要求删除
  • 需要重写该方法,让对象比较属性值是否一致

List接口

ArrayList

ArrayList的创建:

List<Integer> al = new ArrayList<Integer>;

List<List<Integer>> al = new ArrayList<List<Integer>>;			// 这种创建方式是对的

List<List<Integer>> al = new ArrayList<ArrayList<Integer>>;		// 这种创建方式是错的

方法(均与索引有关):

函数功能
public void add(int index, E element);
public E remove(int index);
public E set(int index, E element);
public E get(int index);

示例:

package com.itheima.collection.list;

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

public class ListDemo1 {
    public static void main(String[] args) {

        List<String> list = new ArrayList<>();

        list.add("张三");
        list.add("李四");
        list.add("王五");

        list.set(0, "赵六");
        list.remove(1);		// 根据索引删除:List接口的特点,传入的参数是int类型的索引

        System.out.println(list.get(0));
        System.out.println(list);

        System.out.println("-------------------------");

        List<Integer> list2 = new ArrayList<>();

        list2.add(111);        // Integer e = 111;
        list2.add(222);
        list2.add(333);

        list2.remove(Integer.valueOf(222));		// 根据元素删除,需要这样写,以跟索引删除的方法区分开
        System.out.println(list2);
    }
}
  • 根据索引删除元素:是List接口(子)的特点

  • 根据元素删除元素:是Collection接口(父)的特点

LinkedList

函数功能
public void add(int index, E element);
public void addFirst(E e);
public void addLast(E e)
public E remove(int index);
public E removeFirst()
public E removeLast()
public E set(int index, E element);
public E get(int index);
public E getFirst()
public E getLast()

Set接口

TreeSet

函数功能
boolean addAll(Collection<? extends E> c)
通用方法里面,针对对象的删除
删 + 增改(移除元素并重新添加)
E first()
E last()

HashSet

函数功能
通用方法里面,按照元素的增
通用方法里面,按照元素的删
删 + 增
不具备

LinkedHashSet

用到再说

Map接口

通用函数

函数操作
V put(K, key, V value)
V remove(Object key)
void clear()
boolean containsKey(Object key)包含
boolean containsValue(Obejct value)
boolean isEmpty()判空
int size()返回集合中元素的数量

TreeMap

函数功能
通用方法里面的
通用方法里面的
删 + 增

HashMap

函数功能
通用方法里面的
通用方法里面的
删 + 增
V get(Object k)V getOrDefault(Object k, V Default_Value)

LinkedHashMap

用到再说

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值