Java List查找

Java中的List是一种常用的集合类型,它提供了丰富的操作方法,包括添加元素、删除元素、查找元素等。其中,查找元素是经常会使用到的操作,本文将从多个方面对Java List查找做详细阐述。

一、基础查找

Java List提供了多种基础查找方法,如contains()、indexOf()、lastIndexOf()等。

contains()方法用于判断List中是否包含某个元素,其函数原型为:

public boolean contains(Object o)

示例代码如下:

List<String> list = new ArrayList<>();
list.add("A");
list.add("B");
list.add("C");
boolean aIsExist = list.contains("A");
if (aIsExist) {
    System.out.println("A is exist.");
} else {
    System.out.println("A is not exist.");
}

上面的代码中,我们创建了一个包含”A”、”B”、”C”三个元素的List,调用contains()方法判断”A”是否存在。

indexOf()和lastIndexOf()方法用于查找某个元素在List中的位置,区别在于indexOf()从前往后查找,lastIndexOf()从后往前查找。它们的函数原型分别为:

public int indexOf(Object o)
public int lastIndexOf(Object o)

示例代码如下:

List<String> list = new ArrayList<>();
list.add("A");
list.add("B");
list.add("A");
int firstAIndex = list.indexOf("A");
int lastAIndex = list.lastIndexOf("A");
System.out.println("First A index is " + firstAIndex + ", last A index is " + lastAIndex);

上面的代码中,我们创建了一个包含”A”、”B”、”A”三个元素的List,调用indexOf()和lastIndexOf()方法查找”A”的位置。

二、自定义查找

如果默认提供的查找方法无法满足需求,我们可以自定义查找方法。自定义查找方法通常需要两个步骤:1、定义一个接口或抽象类;2、根据实际需求实现接口或抽象类。

下面是一个自定义查找接口的示例:

public interface ListSearcher<T> {
    int search(List<T> list, T target);
}

这个接口有一个search()方法,用于在List中查找目标元素的位置。

我们需要根据实际需求实现这个接口,下面是一个实现示例:假设我们有一个Person类:

public class Person {
    private String name;
    private int age;

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

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }
}

现在我们要在一个包含Person元素的List中查找一个age等于18的Person对象。实现代码如下:

public class PersonSearcher implements ListSearcher<Person> {
    @Override
    public int search(List<Person> list, Person target) {
        int size = list.size();
        for (int i = 0; i < size; i++) {
            Person person = list.get(i);
            if (person.getAge() == target.getAge()) {
                return i;
            }
        }
        return -1;
    }
}

上面的代码中,我们创建了一个PersonSearcher类,实现了ListSearcher接口,使用for循环遍历List中的元素,如果找到了目标元素则返回其位置,否则返回-1。

使用示例代码如下:

List<Person> list = new ArrayList<>();
list.add(new Person("A", 18));
list.add(new Person("B", 20));
list.add(new Person("C", 18));
PersonSearcher searcher = new PersonSearcher();
Person target = new Person("", 18); // 只用age作为查找条件,name可以为空
int index = searcher.search(list, target);
if (index != -1) {
    System.out.println("Target is in " + index);
} else {
    System.out.println("Target is not exist.");
}

上面的代码中,我们创建了一个包含三个Person元素的List,使用PersonSearcher查找age等于18的Person对象。

三、Lambda表达式查找

Java 8中引入了Lambda表达式,可以使用Lambda表达式来简化代码。假设我们有一个List<String>,我们要查找所有以”A”开头的元素,可以使用Lambda表达式实现:

List<String> list = new ArrayList<>();
list.add("Alice");
list.add("Bob");
list.add("Amy");
list.add("Andy");
list.add("Alex");
List<String> result = list.stream()
        .filter(s -> s.startsWith("A"))
        .collect(Collectors.toList());
System.out.println(result);

上面的代码中,我们通过stream()方法将List转换成Stream对象,在Stream对象上使用filter()方法过滤出以”A”开头的元素,最后使用collect()方法将结果转换成List形式输出。

四、并发查找

如果我们的List比较大,单线程查找有可能会很慢,可以使用并发查找来提升性能。

Java提供了多种并发容器,如ConcurrentHashMap、CopyOnWriteArrayList等,在这里我们使用并发查找的核心类——ForkJoinPool。

假设我们有一个很大的List,我们要查找其中所有以”A”开头的元素,使用ForkJoinPool可以将这个大任务分割成多个小任务,分别在不同的线程中并发执行,从而提升查找速度。

示例代码如下:

List<String> list = new ArrayList<>();
for (int i = 0; i < 10000; i++) {
    list.add(UUID.randomUUID().toString());
}
long start = System.currentTimeMillis();
ForkJoinPool pool = new ForkJoinPool();
List<String> result = pool.invoke(new FindTask(list, "A"));
long end = System.currentTimeMillis();
System.out.println("Time cost is " + (end - start) + "ms, result size is " + result.size());

上面的代码中,我们先创建了一个包含10000个随机字符串的List,然后使用ForkJoinPool执行查找任务,最后打印出结果的数量和执行时间。

FindTask是我们自定义的查找任务类,其实现代码如下:

public class FindTask extends RecursiveTask<List<String>> {
    private List<String> list;
    private String prefix;

    public FindTask(List<String> list, String prefix) {
        this.list = list;
        this.prefix = prefix;
    }

    @Override
    protected List<String> compute() {
        List<String> result = new ArrayList<>();
        if (list.size() <= 100) { // 小任务直接计算
            for (String s : list) {
                if (s.startsWith(prefix)) {
                    result.add(s);
                }
            }
            return result;
        } else { // 大任务分割成小任务并继续拆分
            int mid = list.size() / 2;
            FindTask leftTask = new FindTask(list.subList(0, mid), prefix);
            FindTask rightTask = new FindTask(list.subList(mid, list.size()), prefix);
            leftTask.fork();
            rightTask.fork();
            List<String> leftResult = leftTask.join();
            List<String> rightResult = rightTask.join();
            result.addAll(leftResult);
            result.addAll(rightResult);
            return result;
        }
    }
}

上面的代码中,我们判断任务是否小于等于100,如果是则直接计算,否则将任务分割成两个小任务,分别在不同的线程中并发执行,最后将结果合并。

总结

Java List提供了多种查找方法,包括基础查找、自定义查找、Lambda表达式查找和并发查找。我们可以根据实际需求选择不同的方式来进行查找操作,提高代码的性能和可读性。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/188430.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-28 13:30
下一篇 2024-11-28 13:30

相关推荐

  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • java client.getacsresponse 编译报错解决方法

    java client.getacsresponse 编译报错是Java编程过程中常见的错误,常见的原因是代码的语法错误、类库依赖问题和编译环境的配置问题。下面将从多个方面进行分析…

    编程 2025-04-29
  • Java腾讯云音视频对接

    本文旨在从多个方面详细阐述Java腾讯云音视频对接,提供完整的代码示例。 一、腾讯云音视频介绍 腾讯云音视频服务(Cloud Tencent Real-Time Communica…

    编程 2025-04-29
  • Java Bean加载过程

    Java Bean加载过程涉及到类加载器、反射机制和Java虚拟机的执行过程。在本文中,将从这三个方面详细阐述Java Bean加载的过程。 一、类加载器 类加载器是Java虚拟机…

    编程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介绍

    本文将详细介绍Java Milvus SearchParam withoutFields的相关知识和用法。 一、什么是Java Milvus SearchParam without…

    编程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java语言中的一个版本,于2014年3月18日发布。本文将从多个方面对Java 8中某一周的周一进行详细的阐述。 一、数组处理 Java 8新特性之一是Stream…

    编程 2025-04-29
  • Tensor to List的使用

    Tensor to List是TensorFlow框架提供的一个非常有用的函数,在很多的深度学习模型中都会用到。它的主要功能是将TensorFlow中的张量(Tensor)转换为P…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29
  • VSCode为什么无法运行Java

    解答:VSCode无法运行Java是因为默认情况下,VSCode并没有集成Java运行环境,需要手动添加Java运行环境或安装相关插件才能实现Java代码的编写、调试和运行。 一、…

    编程 2025-04-29
  • Java任务下发回滚系统的设计与实现

    本文将介绍一个Java任务下发回滚系统的设计与实现。该系统可以用于执行复杂的任务,包括可回滚的任务,及时恢复任务失败前的状态。系统使用Java语言进行开发,可以支持多种类型的任务。…

    编程 2025-04-29

发表回复

登录后才能评论