공용 언어 런타임의 형식 전달
형식 전달을 사용하면 원본 어셈블리를 사용하는 응용 프로그램을 다시 컴파일하지 않고도 형식을 다른 어셈블리로 이동할 수 있습니다.
예를 들어, 응용 프로그램에서 Utility.dll이라는 어셈블리의 Example 클래스를 사용할 경우, Utility.dll 개발자는 어셈블리를 리팩터링하고 해당 과정에서 Example 클래스를 다른 어셈블리로 이동할 수 있습니다. 이전 버전의 Utility.dll이 새 버전의 Utility.dll과 관련 어셈블리로 바뀐 경우 Example 클래스를 사용하는 응용 프로그램은 새 버전의 Utility.dll에서 Example 클래스를 찾을 수 없기 때문에 실패합니다.
Utility.dll 개발자는 TypeForwardedToAttribute 특성으로 Example 클래스에 대한 요청을 전달하여 이를 방지할 수 있습니다. 새 버전의 Utility.dll에 이 특성이 적용된 경우 Example 클래스에 대한 요청은 현재 해당 클래스가 들어 있는 어셈블리로 전달됩니다. 기존 응용 프로그램은 다시 컴파일하지 않고도 정상적으로 작동합니다.
참고 |
---|
.NET Framework 버전 2.0에서는 Visual Basic으로 작성된 어셈블리의 형식을 전달할 수 없습니다.그러나 Visual Basic으로 작성된 응용 프로그램에서 전달된 형식을 사용할 수는 있습니다.즉, 응용 프로그램에서 C# 또는 C++로 코딩된 어셈블리를 사용하며 해당 어셈블리의 형식이 다른 어셈블리로 전달된 경우 Visual Basic 응용 프로그램에서 전달된 형식을 사용할 수 있습니다. |
형식 전달
다음 네 단계를 통해 형식을 전달할 수 있습니다.
형식의 소스 코드를 원본 어셈블리에서 대상 어셈블리로 이동합니다.
해당 형식이 있었던 어셈블리에서 이동된 형식에 대해 TypeForwardedToAttribute를 추가합니다. 다음 코드에서는 이동된 Example 형식의 특성을 보여 줍니다.
[assembly:TypeForwardedToAttribute(typeof(Example))]
[assembly:TypeForwardedToAttribute(Example::typeid)]
해당 형식이 현재 들어 있는 어셈블리를 컴파일합니다.
해당 형식이 있었던 어셈블리를 현재 해당 형식이 들어 있는 어셈블리에 대한 참조를 사용하여 다시 컴파일합니다. 예를 들어, 명령줄에서 C# 파일을 컴파일할 경우 /reference(C# 컴파일러 옵션) 옵션을 사용하여 해당 형식이 들어 있는 어셈블리를 지정합니다. C++의 경우 소스 파일에서 #using 지시문을 사용하여 해당 형식이 들어 있는 어셈블리를 지정합니다.