Inferred Delegate Type
C#에서는 람다 식(Lambda Expressions)을 사용할 때, 컴파일러가 람다 식의 반환 타입과 매개변수 타입을 자동으로 추론하는 기능을 제공합니다. 이를 Inferred Delegate Type이라고 합니다. C# 10부터 이 기능이 더욱 강화되어, 별도로 Func<T>
나 Action<T>
같은 대리자 타입을 지정하지 않아도 자연스럽게 추론됩니다.
1. 기본적인 예제
아래는 Inferred Delegate Type
을 사용하는 간단한 예제입니다.
var add = (int x, int y) => x + y;
Console.WriteLine(add(3, 5)); // 출력: 8
위 코드에서 add
변수는 (int, int) -> int
형태의 대리자를 가리키며, 명시적으로 Func<int, int, int>
를 사용하지 않아도 됩니다.
2. 컴파일러가 추론하는 방식
var greet = (string name) => $"Hello, {name}!";
Console.WriteLine(greet("ChatGPT")); // 출력: Hello, ChatGPT!
여기서 greet
변수의 타입은 컴파일러가 Func<string, string>
으로 자동 추론합니다.
3. 여러 매개변수와 다양한 반환 타입
var multiply = (double a, double b) => a * b;
var isEven = (int n) => n % 2 == 0;
multiply
는Func<double, double, double>
타입으로 추론됩니다.isEven
은Func<int, bool>
타입으로 추론됩니다.
4. 대리자 타입과 혼용
C# 9 이하에서는 Func<T>
나 Action<T>
을 명시적으로 지정해야 했지만, C# 10부터는 이를 생략할 수 있습니다.
Func<int, int, int> oldWay = (x, y) => x + y;
var newWay = (int x, int y) => x + y;
oldWay
는 명시적으로 Func<int, int, int>
를 사용했지만, newWay
는 타입을 지정하지 않아도 자동 추론됩니다.
5. 로컬 함수와 비교
로컬 함수(Local Function)와 비교하면 다음과 같은 차이가 있습니다.
// 로컬 함수 방식
int Add(int x, int y) => x + y;
// Inferred Delegate Type 방식
var addLambda = (int x, int y) => x + y;
로컬 함수는 명확한 메서드 시그니처를 가지지만, 람다식은 가볍고 간결한 문법을 제공합니다.
6. 활용 예제: 리스트 필터링
Inferred Delegate Type을 활용하면 컬렉션을 다룰 때 더욱 직관적으로 작성할 수 있습니다.
var numbers = new List<int> { 1, 2, 3, 4, 5, 6 };
var evenNumbers = numbers.Where(n => n % 2 == 0).ToList();
Console.WriteLine(string.Join(", ", evenNumbers)); // 출력: 2, 4, 6
Where(n => n % 2 == 0)
에서 n
의 타입은 List<int>
의 요소 타입을 기반으로 int
로 자동 추론됩니다.
7. 마무리
- C#의 Inferred Delegate Type을 사용하면
Func<T>
나Action<T>
를 명시하지 않아도 대리자 타입을 컴파일러가 자동으로 추론할 수 있습니다. - 불필요한 타입 명시를 줄여 코드가 더 간결하고 직관적으로 변합니다.
- 컬렉션, 이벤트 핸들링, 비동기 프로그래밍 등 다양한 곳에서 활용될 수 있습니다.