偏函数存在的合理性
Java中的函数编写时写总结然后再进行具体的细化,倘如我们对一个函数的功能不能够完全的总结我们可以使用“演绎法”去解决
为什么要用偏函数呢?我觉得还是一个重用粒度的问题。函数式的编程思想是以一种“演绎法”而非“归纳法”去寻求解决空间。也就是说,它并不是要去归纳问题然后分解问题并解决问题,而是看透问题本质,定义最原初的操作和组合规则,面对问题时,可以通过组合各种函数去解决问题,这也正是“组合子(combinator)”的含义。偏函数则更进一步,将函数求解空间中各个分支也分离出来,形成可以被组合的偏函数。
柯里化存在的合理性
和偏函数相似,也是以一种“演绎法”而非“归纳法”去寻求解决空间,这个的好处是提高了函数的适用性。
使用柯里化可以编写出更加抽象,功能化和高校的函数式代码。 在编写主函数的过程中,往往会把整个逻辑越写越长,这时候中间需要添加一些辅助功能函数如判断文件存在以及关闭文件流,为了方便可以把这些辅助函数按照柯里化风格定义在函数声明中,等待主函数逻辑写完再一一去完善。
柯里化特性可以将复杂逻辑简单化,并能将很多常漏掉的主函数业务逻辑之外的处理暴露在函数的定义阶段,提高代码的健壮性,使函数功能更加细腻化和流程化
1、柯里化技术在提高适用性还是在延迟执行或者固定易变因素等方面有着重要重要的作用,加上scala语言本身就是推崇简洁编码,使得同样功能的函数在定义与转换的时候会更加灵活多样。另外在Spark的源码中有大量运用scala柯里化技术的情况,需要掌握好该技术才能看得懂相关的源代码。
2、在scala柯里化中,闭包也发挥着重要的作用。所谓的闭包就是变量出了函数的定义域外在其他代码块还能其作用,这样的情况称之为闭包。就上述讨论的案例而言,如果没有闭包作用,那么转换后函数其实返回的匿名函数是无法在与第一个参数x相关结合的,自然也就无法保证其所实现的功能是跟原来一致的。