java函数式编程 map_Java8函数式编程:3.10进阶练习:map和filter实现

只用reduce 和Lambda 表达式写出实现Stream 上的map 操作的代码,如果不想返回Stream,可以返回一个List。

// reduce实现map

private Stream map(Stream stream, Function fun) {

return stream.reduce(new ArrayList().stream(), // Stream是reduce参数的的U

(u, t) -> Stream.concat(u, Stream.of(fun.apply(t))),

(a, b) -> Stream.concat(a, b));

}

// 测试方法

// Artist(String name, String nation)

@Test

public void test23() {

System.out.println(

map(Stream.of(

new Artist("a", "aaa"),

new Artist("b", "bbb"),

new Artist("c", "ccc")

), t -> t.getNation()).collect(Collectors.toList())

); // [aaa,bbb,ccc]

}

只用reduce 和Lambda 表达式写出实现Stream 上的filter 操作的代码,如果不想返回Stream,可以返回一个List。

// reduce实现filter

private Stream filter(Stream stream, Predicate pre) {

return stream.reduce(new ArrayList().stream(), // Stream是reduce的U

(u, t) -> {

if (pre.test(t))

return Stream.concat(u, Stream.of(t));

return u;

},

(a, b) -> Stream.concat(a, b)

);

}

// 测试方法

@Test

public void test24() {

System.out.println(

filter(Stream.of(

new Artist("a", "aaa"),

new Artist("b", "bb"),

new Artist("c", "c")

), t -> t.getNation().length() >= 2).collect(Collectors.toList())

);

} // [Artist("a", "aaa"), Artist("b", "bb")]

后话,函数式编程写起来是挺爽,写完了会有种看不懂的感觉... 慢慢习惯就好。关键是reduce方法的使用,下面给出我的看法:

reduce方法有3个:

//1.

Optional reduce(BinaryOperator accumulator);

/*

常规的累计计算器,参数泛型和返回值泛型相同,

具体的累计计算规则源代码注释已经给出,

将stream第一个元素作为初始值,然后和第二个元素累计计算,

结果再次作为初始值,再和第三个元素累计计算,以此类推:

boolean foundAny = false;

T result = null;

for (T element : this stream) {

if (!foundAny) {

foundAny = true;

result = element;

}

else

result = accumulator.apply(result, element);

}

return foundAny ? Optional.of(result) : Optional.empty();

*/

//2.

T reduce(T identity, BinaryOperator accumulator);

/*

具有初始值的累计计算器,和上面的reduce类似,

只是初始值永远固定不变,均为 identity,

并且参数 identity、accumulator 的泛型相同,与返回值泛型亦相同

*/

//3.

U reduce(U identity,

BiFunction accumulator,

BinaryOperator combiner);

/*

累加器带有3个参数,前两个参数和上面的reduce含义相同,

需要注意的是 identity 的泛型和返回值的泛型相同,

而 accumulator 的函数接口变为了 BiFunction,并且支持两种泛型,可以和返回值泛型相同,也可不同,

上面实现 map 方法就有两中泛型参数,U 是 Stream,T 就是 Artist,

最后一个参数 combiner,貌似是和并行有关,大概是并行执行后结果如何合并的方法,这里暂时用 concat 合并,后面再研究

*/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
目录 第1章 lambda表达式 0 1.1 为什么要使用lambda表达式 2 1.2 lambda表达式的语法 4 1.3 函数式接口 6 1.4 方法引用 8 1.5 构造器引用 10 1.6 变量作用域 10 1.7 默认方法 14 1.8 接口中的静态方法 17 练习 18 第2章 Stream API 20 2.1 从迭代器到Stream操作 22 2.2 创建Stream 23 2.3 filtermap和flatMap方法 25 2.4 提取子流和组合流 26 2.5 有状态的转换 27 2.6 简单的聚合方法 28 2.7 Optional类型 29 2.7.1 使用Optional值 29 2.7.2 创建可选值 30 2.7.3 使用flatMap来组合可选值函数 31 2.8 聚合操作 32 2.9 收集结果 33 2.10 将结果收集到Map中 35 2.11 分组和分片 37 2.12 原始类型流 40 2.13 并行流 42 2.14 函数式接口 44 练习 45 第3章使用lambda编程 48 3.1 延迟执行 50 3.2 lambda表达式的参数 51 3.3 选择一个函数式接口 52 3.4 返回函数 55 3.5 组合 56 3.6 延迟 58 3.7 并行操作 59 3.8 处理异常 60 3.9 lambda表达式和泛型 63 3.10 一元操作 65 练习 67 第4章 JavaFX 72 4.1 Java GUI编程简史 74 4.2 你好,JavaFX! 75 4.3 事件处理 76 4.4 JavaFX属性 77 4.5 绑定 80 4.6 布局 85 4.7 FXML 91 4.8 CSS 95 4.9 动画和特殊效果 97 4.10 不寻常的控件 100 练习 103 第5章新的日期和时间API 106 5.1 时间线 108 5.2 本地日期 110 5.3 日期校正器 113 5.4 本地时间 114 5.5 带时区的时间 115 5.6 格式化和解析 119 5.7 与遗留代码互操作 122 练习 123 第6章并发增强 126 6.1 原子值 128 6.2 ConcurrentHashMap改进 131 6.2.1 更新值 132 6.2.2 批量数据操作 134 6.2.3 Set视图 136 6.3 并行数组操作 137 6.4 可完成的Future 138 6.4.1 Future 138 6.4.2 编写Future 139 6.4.3 Future流水线 139 6.4.4 编写异步操作 141 练习 143 第7章 JavaScript引擎——Nashorn 146 7.1 从命令行运行Nashorn 148 7.2 从Java运行Nashorn 149 7.3 调用方法 150 7.4 构造对象 151 7.5 字符串 153 7.6 数字 153 7.7 使用数组 154 7.8 列表和映射 155 7.9 lambda表达式 156 7.10 继承Java类及实现Java接口 157 7.11 异常 158 7.12 Shell脚本 159 7.12.1 执行Shell命令 159 7.12.2 字符串插值 160 7.12.3 脚本输入 161 7.13 Nashorn和JavaFX 162 练习 164 第8章杂项改进 166 8.1 字符串 168 8.2 数字类 168 8.3 新的数学函数 169 8.4 集合 170 8.4.1 集合类中添加的方法 170 8.4.2 比较器 171 8.4.3 Collections类 173 8.5 使用文件 173 8.5.1 读取文件行的流 173 8.5.2 遍历目录项的流 175 8.5.3 Base64编码 176 8.6 注解 177 8.6.1 可重复的注解 177 8.6.2 可用于类型的注解 179 8.6.3 方法参数反射 181 8.7 其他一些细微的改进 182 8.7.1 Null检查 182 8.7.2 延迟消息 182 8.7.3 正则表达式 183 8.7.4 语言环境 183 8.7.5 JDBC 185 练习 185 第9章你可能错过的Java 7特性 188 9.1 异常处理改进 190 9.1.1 try-with-resources语句 190 9.1.2 忽略异常 191 9.1.3 捕获多个异常 192 9.1.4 更简单地处理反射方法的异常 193 9.2 使用文件 193 9.2.1 Path 194 9.2.2 读取和写入文件 196 9.2.3 创建文件和目录 197 9.2.4

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值