Guava库中的`ImmutableCollections`进行集合操作的示例

Guava库中的ImmutableCollections进行集合操作的示例,包括创建不可变集合和常见的集合操作:

1. 创建不可变集合

使用ImmutableSet创建不可变集合
java 复制代码
import com.google.common.collect.ImmutableSet;

public class ImmutableSetExample {
    public static void main(String[] args) {
        ImmutableSet<String> fruits = ImmutableSet.of("apple", "banana", "cherry");
        System.out.println("ImmutableSet: " + fruits);
    }
}
使用ImmutableList创建不可变列表
java 复制代码
import com.google.common.collect.ImmutableList;

public class ImmutableListExample {
    public static void main(String[] args) {
        ImmutableList<String> colors = ImmutableList.of("red", "green", "blue");
        System.out.println("ImmutableList: " + colors);
    }
}
使用ImmutableMap创建不可变映射
java 复制代码
import com.google.common.collect.ImmutableMap;

public class ImmutableMapExample {
    public static void main(String[] args) {
        ImmutableMap<String, Integer> numberMap = ImmutableMap.of("one", 1, "two", 2, "three", 3);
        System.out.println("ImmutableMap: " + numberMap);
    }
}

2. 使用Builder构建不可变集合

java 复制代码
import com.google.common.collect.ImmutableSet;

public class ImmutableBuilderExample {
    public static void main(String[] args) {
        ImmutableSet<String> set = ImmutableSet.<String>builder()
                .add("apple")
                .add("banana")
                .add("cherry")
                .build();
        System.out.println("ImmutableSet built with builder: " + set);
    }
}

3. 集合操作示例

过滤和转换

使用Guava的FluentIterable进行集合的过滤和转换:

java 复制代码
import com.google.common.collect.FluentIterable;
import com.google.common.base.Predicate;

import java.util.Arrays;
import java.util.List;

public class FilterExample {
    public static void main(String[] args) {
        List<String> strings = Arrays.asList("one", "two", "three", "four");
        Predicate<String> startsWithT = input -> input.startsWith("t");
        List<String> filtered = FluentIterable.from(strings).filter(startsWithT).toList();
        System.out.println("Filtered list: " + filtered); // 输出: [two, three]
    }
}
集合的交集、差集和并集

使用Guava的Sets类进行集合的交集、差集和并集操作:

java 复制代码
import com.google.common.collect.Sets;

import java.util.Set;

public class SetOperationsExample {
    public static void main(String[] args) {
        Set<String> setA = ImmutableSet.of("apple", "banana", "cherry");
        Set<String> setB = ImmutableSet.of("banana", "date", "fig");

        Set<String> union = Sets.union(setA, setB);
        Set<String> intersection = Sets.intersection(setA, setB);
        Set<String> difference = Sets.difference(setA, setB);
        Set<String> symmetricDifference = Sets.symmetricDifference(setA, setB);

        System.out.println("Union: " + union);
        System.out.println("Intersection: " + intersection);
        System.out.println("Difference: " + difference);
        System.out.println("Symmetric Difference: " + symmetricDifference);
    }
}

4. 使用copyOf方法

使用copyOf方法创建不可变集合,可以避免不必要的拷贝操作:

java 复制代码
import com.google.common.collect.ImmutableSet;

import java.util.HashSet;
import java.util.Set;

public class CopyOfExample {
    public static void main(String[] args) {
        Set<String> modifiableSet = new HashSet<>();
        modifiableSet.add("apple");
        modifiableSet.add("banana");

        ImmutableSet<String> immutableSet = ImmutableSet.copyOf(modifiableSet);
        System.out.println("ImmutableSet from copyOf: " + immutableSet);
    }
}

这些示例展示了如何使用Guava库中的不可变集合以及如何进行常见的集合操作。不可变集合的优势在于它们是线程安全的,适合在多线程环境中使用,同时也能提高代码的可读性和维护性。

相关推荐
苏瞳儿4 小时前
java对数据库的增删改查
java·数据库·oracle
zhangjw344 小时前
Java基础语法:变量、数据类型与运算符,从原理到实战
java·开发语言
yaoxin5211237 小时前
384. Java IO API - Java 文件复制工具:Copy 示例完整解析
java·开发语言·python
NotFound4867 小时前
实战指南如何实现Java Web 拦截机制:Filter 与 Interceptor 深度分享
java·开发语言·前端
Ava的硅谷新视界8 小时前
用了一天 Claude Opus 4.7,聊几点真实感受
开发语言·后端·编程
rabbit_pro8 小时前
Python调用onnx模型
开发语言·python
一 乐9 小时前
医院挂号|基于springboot + vue医院挂号管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·医院挂号管理系统
浪客川9 小时前
【百例RUST - 010】字符串
开发语言·后端·rust
鱼鳞_9 小时前
Java学习笔记_Day29(异常)
java·笔记·学习
烟锁池塘柳09 小时前
一文讲透 C++ / Java 中方法重载(Overload)与方法重写(Override)在调用时机等方面的区别
java·c++·面向对象