🛠️ 처음부터 만드는 Curry — 함수 부분 적용으로 재사용성 높이기
# Curry란?
Curry는 여러 개의 인자를 받는 함수를 한 번에 하나씩 인자를 받는 함수 체인으로 변환하는 기법입니다. 함수형 프로그래밍의 핵심 패턴으로, 부분 적용(Partial Application)을 우아하게 구현합니다.
```typescript
function curry any>(fn: T): any {
return function curried(...args: Parameters): any {
if (args.length >= fn.length) {
return fn(...args);
}
return (...nextArgs: any[]) => curried(...args, ...nextArgs);
};
}
```
1. `fn.length`로 함수가 필요한 인자 개수 확인
2. 전달된 인자가 충분하면 즉시 실행
3. 부족하면 새 함수 반환 (나머지 인자 대기)
```typescript
const add = (a: number, b: number, c: number) => a + b + c;
const curriedAdd = curry(add);
// 여러 방식으로 호출 가능
curriedAdd(1)(2)(3); // 6
curriedAdd(1, 2)(3); // 6
curriedAdd(1)(2, 3); // 6
curriedAdd(1, 2, 3); // 6
// 부분 적용으로 새 함수 생성
const add1 = curriedAdd(1);
const add1_2 = add1(2);
console.log(add1_2(3)); // 6
```
API 요청 래퍼 만들기:
```typescript
const fetch_ = curry((method: string, url: string, data?: any) =>
fetch(url, { method, body: JSON.stringify(data) })
);
const get = fetch_('GET');
const post = fetch_('POST');
const postUser = post('/api/users');
```
이점: 고정된 인자는 미리 설정하고, 필요할 때만 나머지 전달 가능. 코드 재사용성이 대폭 증가합니다.
Curry는 여러 개의 인자를 받는 함수를 한 번에 하나씩 인자를 받는 함수 체인으로 변환하는 기법입니다. 함수형 프로그래밍의 핵심 패턴으로, 부분 적용(Partial Application)을 우아하게 구현합니다.
```typescript
function curry
return function curried(...args: Parameters
if (args.length >= fn.length) {
return fn(...args);
}
return (...nextArgs: any[]) => curried(...args, ...nextArgs);
};
}
```
동작 원리
1. `fn.length`로 함수가 필요한 인자 개수 확인
2. 전달된 인자가 충분하면 즉시 실행
3. 부족하면 새 함수 반환 (나머지 인자 대기)
실제 사용 예
```typescript
const add = (a: number, b: number, c: number) => a + b + c;
const curriedAdd = curry(add);
// 여러 방식으로 호출 가능
curriedAdd(1)(2)(3); // 6
curriedAdd(1, 2)(3); // 6
curriedAdd(1)(2, 3); // 6
curriedAdd(1, 2, 3); // 6
// 부분 적용으로 새 함수 생성
const add1 = curriedAdd(1);
const add1_2 = add1(2);
console.log(add1_2(3)); // 6
```
실무 활용
API 요청 래퍼 만들기:
```typescript
const fetch_ = curry((method: string, url: string, data?: any) =>
fetch(url, { method, body: JSON.stringify(data) })
);
const get = fetch_('GET');
const post = fetch_('POST');
const postUser = post('/api/users');
```
이점: 고정된 인자는 미리 설정하고, 필요할 때만 나머지 전달 가능. 코드 재사용성이 대폭 증가합니다.
👁 0 views
Comments (0)
💬
No comments yet.
Be the first to comment!