🛠️ 처음부터 만드는 Curry — 함수 인자를 단계별로 적용하기
# Curry란?
여러 인자를 받는 함수를 단일 인자씩 받는 함수들의 체인으로 변환하는 패턴입니다.
```js
const add = (a, b, c) => a + b + c;
const curriedAdd = curry(add);
const add5 = curriedAdd(5); // a=5
const add5_3 = add5(3); // b=3
const result = add5_3(2); // c=2 → 10
```
```js
function curry(fn) {
const arity = fn.length; // 함수의 인자 개수
return function curried(...args) {
if (args.length >= arity) {
return fn(...args);
}
return (...nextArgs) => curried(...args, ...nextArgs);
};
}
```
```js
// 함수형 프로그래밍: 부분 적용으로 새로운 함수 만들기
const multiply = curry((a, b, c) => a * b * c);
const multiplyBy2 = multiply(2);
const multiplyBy2And3 = multiplyBy2(3);
console.log(multiplyBy2And3(5)); // 30
// 배열의 map과 조합
const divide = curry((a, b) => a / b);
const divideBy10 = divide(10);
[100, 50, 25].map(divideBy10); // [10, 5, 2.5]
```
✅ 함수형 프로그래밍 라이브러리 (Ramda, Lodash/fp)
✅ Redux와 함께 액션 크리에이터 작성
✅ 고차 함수 패턴에서 부분 적용이 필요할 때
⚠️ 주의: 과도한 currying은 코드 가독성을 떨어뜨립니다. 필요한 곳에만 사용하세요.
📚 [JavaScript.info - Currying](https://javascript.info/currying-partials)
여러 인자를 받는 함수를 단일 인자씩 받는 함수들의 체인으로 변환하는 패턴입니다.
```js
const add = (a, b, c) => a + b + c;
const curriedAdd = curry(add);
const add5 = curriedAdd(5); // a=5
const add5_3 = add5(3); // b=3
const result = add5_3(2); // c=2 → 10
```
기본 구현
```js
function curry(fn) {
const arity = fn.length; // 함수의 인자 개수
return function curried(...args) {
if (args.length >= arity) {
return fn(...args);
}
return (...nextArgs) => curried(...args, ...nextArgs);
};
}
```
실제 사용
```js
// 함수형 프로그래밍: 부분 적용으로 새로운 함수 만들기
const multiply = curry((a, b, c) => a * b * c);
const multiplyBy2 = multiply(2);
const multiplyBy2And3 = multiplyBy2(3);
console.log(multiplyBy2And3(5)); // 30
// 배열의 map과 조합
const divide = curry((a, b) => a / b);
const divideBy10 = divide(10);
[100, 50, 25].map(divideBy10); // [10, 5, 2.5]
```
언제 쓸까?
✅ 함수형 프로그래밍 라이브러리 (Ramda, Lodash/fp)
✅ Redux와 함께 액션 크리에이터 작성
✅ 고차 함수 패턴에서 부분 적용이 필요할 때
⚠️ 주의: 과도한 currying은 코드 가독성을 떨어뜨립니다. 필요한 곳에만 사용하세요.
📚 [JavaScript.info - Currying](https://javascript.info/currying-partials)
👁 0 views
Comments (0)
💬
No comments yet.
Be the first to comment!