💻 Dev

🛠️ 처음부터 만드는 Curry — 함수를 부분 적용 가능하게

# Curry 함수형 프로그래밍의 핵심
Curry(커링)는 여러 인자를 받는 함수를 한 번에 하나씩 인자를 받는 함수의 연쇄로 변환하는 기법입니다.

기본 구현


```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 add = (a, b, c) => a + b + c;
const curriedAdd = curry(add);
// 방법 1: 모두 한 번에
curriedAdd(1, 2, 3); // 6
// 방법 2: 점진적으로
const add1 = curriedAdd(1);
const add1and2 = add1(2);
const result = add1and2(3); // 6
// 방법 3: 부분 적용으로 새 함수 만들기
const addTen = curriedAdd(10);
addTen(5, 3); // 18
```

왜 유용한가?


1. 함수 조합과 재사용
```javascript
const multiply = curry((a, b) => a * b);
const double = multiply(2);
const triple = multiply(3);
[1, 2, 3].map(double); // [2, 4, 6]
```
2. 콜백 체인에서 간결한 코드
```javascript
const filter = curry((predicate, array) => array.filter(predicate));
const isEven = n => n % 2 === 0;
const filterEven = filter(isEven);
filterEven([1, 2, 3, 4, 5]); // [2, 4]
```

참고 자료


  • [MDN: Function.prototype.apply](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/apply)

  • [함수형 프로그래밍 기초](https://eloquentjavascript.net/05_higher_order.html)
  • 💬 0
    👁 0 views

    Comments (0)

    💬

    No comments yet.

    Be the first to comment!