基于多种智能优化算法的山地无人机三维路径规划方法研究(Matlab代码实现)
2026/5/4 7:46:27
在Java的Stream API中,我们构建的是一个“流水线式的数据处理过程”,就像搭建一条工厂生产线:
intermediate operation)terminal operation),它才启动整条流水线。Intermediate Operation):搭建流水线,不启动定义:一个方法返回一个Stream,就是一个中间操作。
作用:添加一个“处理环节”,但本身不触发数据处理。
Stream<String>stream=List.of("a","bb","ccc").stream();Stream<Integer>lengths=stream.map(str->str.length());// 中间操作✅ 你只是“配置”了处理流程,没有处理数据。就像装了一个“长度计算”的机械臂,还没开电源。
定义:一个方法返回的不是Stream(或是void),那就是终端操作。
作用:触发数据从源头一个个“通过中间操作”,并产出结果。
inttotal=List.of("a","bb","ccc").stream().map(String::length)// 中间操作.reduce(0,Integer::sum);// 终端操作System.out.println("总长度 = "+total);// 输出 6✅ 数据此时才真正流过map,然后被reduce聚合求和。
varresult=List.of("apple","banana","avocado").stream().filter(s->s.startsWith("a"))// 过滤出以 a 开头的.map(String::toUpperCase)// 转大写.sorted()// 排序.toList();// 终端操作:生成结果列表System.out.println(result);// 输出: [APPLE, AVOCADO]📌 注意:这些.filter(),.map(),.sorted()每一步都只是排流程,只有.toList()才触发执行。
varstream=Stream.of(1,2,3,4);// 第一次使用,合法varmapped=stream.map(i->i+1);// 第二次使用,❌ 非法!stream 已经用过varlist=stream.toList();// 会抛 IllegalStateException💥 错误信息:
java.lang.IllegalStateException:stream has already been operated upon or closed// 正确做法:重新从集合创建新 Streamvarsource=List.of(1,2,3,4);varmapped=source.stream().map(i->i+1).toList();// ✅varfiltered=source.stream().filter(i->i%2==0).toList();// ✅| 操作类型 | 特征描述 | 是否触发处理 | 返回值类型 | 示例方法 |
|---|---|---|---|---|
| 中间操作 | 构建流水线,返回新的 Stream | ❌ 否 | Stream | map,filter,sorted |
| 终端操作 | 启动流水线,返回结果或副作用 | ✅ 是 | 非Stream类型 | collect,toList,reduce,forEach |
map()和filter()构建一个处理流程,但不要调用终端操作,验证是否执行了逻辑?Stream对象,观察异常,并改用集合重新创建 Stream。