当前位置: 首页 > news >正文

做presentation的网站wordpress搜索框去掉

做presentation的网站,wordpress搜索框去掉,建设网站设计论文范文,微信分销平台是什么意思Java Stream 流详解 Stream 是 Java 8 引入的 API,用于高效处理集合数据(如 List、Set、Map 等)。它支持函数式编程风格,能实现复杂的查询、过滤、映射等操作,并支持并行处理以提升性能。核心特点 非存储数据结构&…

Java Stream 流详解

Stream 是 Java 8 引入的 API,用于高效处理集合数据(如 ListSetMap 等)。它支持函数式编程风格,能实现复杂的查询、过滤、映射等操作,并支持并行处理以提升性能。


核心特点
  1. 非存储数据结构:不存储数据,仅通过计算管道传递数据。
  2. 不修改源数据:所有操作生成新流,不影响原始集合。
  3. 惰性求值:中间操作延迟执行,直到遇到终止操作才触发计算。
  4. 可消费性:流只能被遍历一次,终止操作后流即失效。

操作分类
类型操作示例
创建流从集合/数组生成流list.stream(), Arrays.stream(array)
中间操作返回新流(延迟执行)filter(), map(), sorted(), distinct()
终止操作触发计算并返回结果(非流类型)collect(), forEach(), reduce(), count()

常用操作详解
1. 创建流
// 从集合创建
List<String> list = Arrays.asList("a", "b", "c");
Stream<String> stream1 = list.stream();// 从数组创建
String[] array = {"a", "b", "c"};
Stream<String> stream2 = Arrays.stream(array);// 直接创建
Stream<String> stream3 = Stream.of("a", "b", "c");// 生成无限流(需限制大小)
Stream<Integer> infiniteStream = Stream.iterate(0, n -> n + 1).limit(10); // 0,1,2,...,9
2. 中间操作(链式调用)
  • filter(Predicate<T>):过滤元素

    stream.filter(s -> s.startsWith("a")); // 保留以"a"开头的元素
    
  • map(Function<T,R>):元素转换

    stream.map(String::toUpperCase); // 转为大写 ["A","B","C"]
    
  • flatMap(Function<T,Stream<R>>):扁平化嵌套流

    List<List<String>> nestedList = Arrays.asList(Arrays.asList("a", "b"),Arrays.asList("c", "d")
    );
    nestedList.stream().flatMap(List::stream) // 合并为["a","b","c","d"].forEach(System.out::println);
    
  • distinct():去重

    Stream.of(1, 2, 2, 3).distinct(); // [1, 2, 3]
    
  • sorted():排序

    Stream.of(3, 1, 2).sorted(); // [1, 2, 3]
    
  • limit(long n):截取前 n 个元素

    Stream.iterate(0, i -> i + 1).limit(3); // [0, 1, 2]
    
3. 终止操作
  • collect(Collector):转换为集合

    List<String> list = stream.collect(Collectors.toList()); // 转List
    Set<String> set = stream.collect(Collectors.toSet());    // 转Set
    
  • forEach(Consumer<T>):遍历元素

    stream.forEach(System.out::println); // 打印每个元素
    
  • reduce():聚合计算

    Optional<Integer> sum = Stream.of(1, 2, 3).reduce((a, b) -> a + b); // 6
    
  • count():统计元素数量

    long count = stream.filter(s -> !s.isEmpty()).count();
    
  • 匹配检查

    boolean anyMatch = stream.anyMatch(s -> s.contains("a")); // 任一元素匹配
    boolean allMatch = stream.allMatch(s -> s.length() > 0);  // 所有元素匹配
    

并行流

通过多线程加速处理大数据集:

// 创建并行流
List<String> result = list.parallelStream().filter(s -> s.length() > 2).collect(Collectors.toList());

注意:并行流需确保操作是线程安全的(如避免修改共享状态)。


实战示例
// 示例:从用户列表中筛选年龄≥18的用户,按姓名排序,提取前10个
List<User> users = ...; // 数据源List<String> result = users.stream().filter(user -> user.getAge() >= 18)  // 过滤.sorted(Comparator.comparing(User::getName)) // 排序.limit(10)                           // 截取.map(User::getName)                  // 提取姓名.collect(Collectors.toList());       // 转为List

注意事项
  1. 流不可复用:终止操作后流即关闭,再次使用会抛出 IllegalStateException
  2. 避免副作用:操作中不要修改外部变量(使用无状态函数)。
  3. 性能考量:小数据集用顺序流,大数据集用并行流(需测试验证)。

Stream API 大幅简化了集合操作代码,结合 Lambda 表达式,使 Java 处理数据更简洁高效。

http://www.dtcms.com/a/466039.html

相关文章:

  • 原型设计、UI设计、前端页面和后台管理页面之间的关系解析
  • Linux的设备驱动模型
  • 鸿蒙NEXT USB服务开发:从基础概念到实战应用
  • 神华集团 两学一做 网站做金融量化的网站
  • 深圳拼团网站建设徐州网站建设报价
  • cpp-httplb库使用手册
  • TextureStreaming针对不同分档机型一般怎么设置
  • 自己做网站2008R2好还是win7qq推广
  • 快速上手!如何用GEO优化让品牌在AI搜索中脱颖而出
  • 道可云人工智能每日资讯|2025世界智能网联汽车大会将在北京举办
  • 【2025最新】【win10】vs2026+qt6.9+opencv(cmake编译opencv_contrib拓展模
  • 惠州做网站电话网站转移后后台无法登陆
  • 学习软件开发的网站公众号软文推广
  • 网站页面大小优化怎么做泉州网站制作哪个好微
  • 代理服务器ip免费邹平县seo网页优化外包
  • 深度学习基础-Chapter 01-感知机和全连接
  • 企业内部网站模板下载网站如何做ICP备案
  • 用js获取浏览器视口高度,并设置元素满屏显示
  • 南山网站建设哪家好静宁县建设局网站
  • Javaer快速掌握Python笔记
  • 刘娇娇做网站骗钱的有什么做网站优化公司
  • ONNX(Open Neural Network Exchange)
  • 医疗发票 OCR 识别:打通医疗费用处理 “堵点” 的技术助手
  • 【C++——面向对象编程综合案例】
  • Pulsar存储计算分离架构设计之存储层BookKeeper(下)
  • 网站建设相对路径广告宣传网站
  • Git 与 GitHub 协同工作流:从0到1搭建版本控制体系
  • VSCode配置PCL1.11.1(CMakeLists.txt)
  • 安装Wasm版的MoonBit工具链
  • 大气的金融网站品质好物推荐怎么上