什么是柯理化
在计算机科学中,柯理化(Currying)是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的新函数的技术。
拓展:这个技术由 Christopher Strachey 以逻辑学家 Haskell Curry 命名的,尽管它是 Moses Schnfinkel 和 Gottlob Frege 发明的。
把含有N个参数的函数转变成,N个只有一个参数的函数
中心思想:减低通用性,提高适用性
具体表现:把一个需要传入多个变量的函数变为多个嵌套函数,并且内层函数会调用上层函数的变量
柯理化函数与普通函数调用方式不一样。
普通函数:函数名(参数1,参数2,…);
柯理化函数:函数名(参数1)(参数2)…
举例:
普通函数
//函数定义
function add(a,b){
return a + b
}
//函数调用
(add(1, 2));
将普通函数改为柯理化函数
//函数定义
function add(a){
return function(b){
return a + b;
}
}
//函数调用
(add(1)(2));
柯理化函数的核心是闭包,内层函数保留父级作用域中的变量。
柯理化是将多参数函数转化为单参数函数的过程,通过返回新的函数来处理剩余参数。这一技术源于逻辑学家Haskell Curry的名字,但实际上由Schnfinkel和Frege提出。柯理化利用闭包特性,将普通函数如`add(a, b)`转换为嵌套函数形式`add(a)(b)`,增强函数的适用性。在实际应用中,柯理化有助于代码复用和模块化,尤其在函数式编程中常见。
863

被折叠的 条评论
为什么被折叠?



