🛠️ 처음부터 만드는 Curry — 부분 적용으로 새로운 함수 만들기
Curry란?
Curry는 여러 개의 인자를 받는 함수를 하나의 인자만 받는 함수로 변환하는 기법입니다. 부분 적용(partial application)으로 새로운 함수를 만들어 함수형 프로그래밍의 강력함을 느낄 수 있습니다.
기본 구현
```javascript
function curry(fn) {
const arity = fn.length; // 함수가 기대하는 인자 개수
return function curried(...args) {
if (args.length >= arity) {
return fn(...args);
}
return (...nextArgs) => curried(...args, ...nextArgs);
};
}
// 사용 예
const add = (a, b, c) => a + b + c;
const curriedAdd = curry(add);
curriedAdd(1)(2)(3); // 6
curriedAdd(1, 2)(3); // 6
curriedAdd(1)(2, 3); // 6
```
실전 예시
```javascript
// API 요청 팩토리
const fetchData = curry((baseUrl, endpoint, userId) =>
fetch(`${baseUrl}${endpoint}/${userId}`)
.then(r => r.json())
);
const apiCall = fetchData('https://api.example.com');
const getUser = apiCall('/users');
getUser(123); // 특정 사용자 조회
// 이벤트 핸들러
const createLogger = curry((level, timestamp, message) =>
console.log(`[${timestamp}] ${level}: ${message}`)
);
const logError = createLogger('ERROR', new Date().toISOString());
logError('Something went wrong'); // 로그 출력
```
TypeScript 버전
```typescript
function curry
const arity = fn.length;
return function curried(...args: any[]): any {
if (args.length >= arity) {
return fn(...args);
}
return (...nextArgs: any[]) => curried(...args, ...nextArgs);
};
}
```
핵심 개념
1. arity: 함수가 기대하는 인자 개수로 언제 실제 함수를 실행할지 결정
2. 클로저: 부분 적용된 인자들을 기억하고 있다가 남은 인자가 오면 합쳐서 실행
3. 함수형 스타일: Pipe와 함께 사용하면 강력한 데이터 파이프라인 구성 가능
더 깊게 배우고 싶다면 [함수형 자바스크립트](https://eloquentjavascript.net/05_higher_order.html) 참고!
👁 0 views
Comments (0)
💬
No comments yet.
Be the first to comment!