Multiply의 반환 타입인 number는 Sum의 반환 타입인 number에 할당 가능하다.
따라서 Sum은 Multiply에 할당 가능하다.
constsum:Sum(sumFirst:number,sumSecond:number)=>{returnsumFirst + sumSecond;};constmultiply:Multiply=sum;// ok
할당 불가능한 경우
다음으로는 할당이 불가능한 예제를 살펴보자.
할당받는 함수의 매개변수 타입 Animal은 할당하는 함수의 매개변수 타입 Dog에 할당 불가능하다.
만족되지 않는 기준이 있으므로 g는 f에 할당할 수 없다.
이 때, 이 기준을 만족해야 하는 이유는 뭘까? 즉, f의 매개변수 타입인 Animal 이 g의 매개변수 타입인 Dog에 할당 불가능하면 왜 g를 f에 할당하지 못해야 할까?
해당 할당을 허용하는 경우를 생각해보자. 만약 f = g 의 할당을 허용한다면 다음과 같이 Animal 타입의 인자를 넘길 수 있을 것이다.
하지만 g 는 인자가 Dog 일 것이라 가정하고, Dog 에만 존재하는 속성 dogProp 에 접근하고 있다. 따라서 런타임 에러가 발생할 수 있다. 이런 상황을 막기 위해 타입스크립트는 이 경우 f = g 와 같은 할당을 금지한다.
매개변수 수가 다른 경우
매개변수 수가 같은 두 함수의 호환성을 비교하는 법에 대해 살펴봤다. 이번엔 매개변수의 수가 다른 경우엔 상황이 어떻게 달라지는지를 다음 두 함수 타입을 통해 살펴보자.
할당하는 함수의 매개변수 수가 더 많은 경우
아래 코드에서 할당하는 함수인 loginWithToken은 할당받는 함수 login에 비해 token: string 이라는 매개변수를 추가적으로 갖고 있다.
이런 경우는 할당이 불가능하다. 만약 이 할당을 허용한다고 생각해보자. 프로그래머는 이 함수를 다음과 같은 식으로 호출할 것이다.
이는 loginWithToken 함수를 token 인자 없이 호출하는 셈이다. loginWithToken 함수 내에서 token을 string 타입이라 생각하고 사용했다면, string이 필요한 자리에 undefined 값이 넘어와서 런타임 에러가 발생할 것이다. 따라서 이런 할당은 허용되지 않는다.
할당받는 함수의 매개변수 수가 더 많은 경우
아래 코드에서 할당하는 함수인 login은 할당받는 함수인 loginWithToken에 비해 매개변수 수가 하나 모자라다.
이런 경우, 초과 매개변수는 무시된다. 그리고 매개변수 수가 같을 때와 동일한 알고리즘으로 호환성을 판단한다. 위의 경우, 초과 매개변수인 token: string 을 제외하고 첫 번째 매개변수는 동일한 타입을 가지므로 할당은 문제 없이 진행된다.
interface Animal { animalProp: string };
interface Dog extends Animal { dogProp: number };
let f = (animal: Animal) => animal.animalProp;
let g = (dog: Dog) => { doSomething(dog.dogProp) };
f = g;
const cat: Animal = { animalProp: 'cute' };
f(cat); // 컴파일러는 통과 시켜 줌
type Login = (id: string) => Response<Data>;
type LoginWithToken = (id: string, token: string) => Response<Data>;