🛠️ 처음부터 만드는 Curry — 함수를 부분 적용 가능하게 만들기
# Curry란?
Curry는 여러 개의 인자를 받는 함수를 하나씩 인자를 받는 함수들의 연쇄로 변환하는 기법입니다.
```javascript
// 일반 함수
const add = (a, b, c) => a + b + c;
add(1, 2, 3); // 6
// Curry로 변환하면
const curriedAdd = curry(add);
const add1 = curriedAdd(1); // 1을 기억한 함수 반환
const add1And2 = add1(2); // 1, 2를 기억한 함수 반환
add1And2(3); // 6 (1 + 2 + 3)
// 또는 한 번에
curriedAdd(1)(2)(3); // 6
```
```javascript
function curry(fn) {
const arity = fn.length; // 함수가 받는 인자 개수
return function curried(...args) {
if (args.length >= arity) {
return fn.apply(this, args);
}
return (...nextArgs) => curried(...args, ...nextArgs);
};
}
```
```javascript
const multiply = (a, b) => a * b;
const curriedMultiply = curry(multiply);
const double = curriedMultiply(2);
const triple = curriedMultiply(3);
[1, 2, 3].map(double); // [2, 4, 6]
[1, 2, 3].map(triple); // [3, 6, 9]
```
Partial은 인자를 정해진 위치에 고정하지만, Curry는 모든 인자가 차례대로 채워질 때까지 함수를 반환합니다. 이는 Compose/Pipe와 함께 사용할 때 강력합니다.
```javascript
const pipe = (...fns) => (x) => fns.reduce((v, f) => f(v), x);
const add = (a, b) => a + b;
const multiply = (a, b) => a * b;
const add5 = curry(add)(5);
const double = curry(multiply)(2);
const calc = pipe(add5, double);
calc(10); // (10 + 5) * 2 = 30
```
참고: [JavaScript Function Composition](https://developer.mozilla.org/en-US/docs/Glossary/First-class_Function)
Curry는 여러 개의 인자를 받는 함수를 하나씩 인자를 받는 함수들의 연쇄로 변환하는 기법입니다.
```javascript
// 일반 함수
const add = (a, b, c) => a + b + c;
add(1, 2, 3); // 6
// Curry로 변환하면
const curriedAdd = curry(add);
const add1 = curriedAdd(1); // 1을 기억한 함수 반환
const add1And2 = add1(2); // 1, 2를 기억한 함수 반환
add1And2(3); // 6 (1 + 2 + 3)
// 또는 한 번에
curriedAdd(1)(2)(3); // 6
```
기본 구현
```javascript
function curry(fn) {
const arity = fn.length; // 함수가 받는 인자 개수
return function curried(...args) {
if (args.length >= arity) {
return fn.apply(this, args);
}
return (...nextArgs) => curried(...args, ...nextArgs);
};
}
```
실전 예제
```javascript
const multiply = (a, b) => a * b;
const curriedMultiply = curry(multiply);
const double = curriedMultiply(2);
const triple = curriedMultiply(3);
[1, 2, 3].map(double); // [2, 4, 6]
[1, 2, 3].map(triple); // [3, 6, 9]
```
고급: 부분 적용과의 차이
Partial은 인자를 정해진 위치에 고정하지만, Curry는 모든 인자가 차례대로 채워질 때까지 함수를 반환합니다. 이는 Compose/Pipe와 함께 사용할 때 강력합니다.
```javascript
const pipe = (...fns) => (x) => fns.reduce((v, f) => f(v), x);
const add = (a, b) => a + b;
const multiply = (a, b) => a * b;
const add5 = curry(add)(5);
const double = curry(multiply)(2);
const calc = pipe(add5, double);
calc(10); // (10 + 5) * 2 = 30
```
참고: [JavaScript Function Composition](https://developer.mozilla.org/en-US/docs/Glossary/First-class_Function)
👁 0 views
Comments (0)
💬
No comments yet.
Be the first to comment!