관리되는 확장 성 프레임 워크

이 장에서는 MEF (Managed Extensibility Framework)에 대해 설명합니다. MEF는 타사 플러그인 확장 성을 위해 사용되거나 느슨하게 결합 된 플러그인 유사 아키텍처의 이점을 일반 애플리케이션에 가져올 수 있습니다.

  • MEF는 가볍고 확장 가능한 응용 프로그램을 만들기위한 라이브러리입니다.

  • 이를 통해 애플리케이션 개발자는 구성없이 확장을 검색하고 사용할 수 있습니다.

  • MEF는 .NET Framework 4의 필수 부분이며 대규모 응용 프로그램의 유연성, 유지 관리 및 테스트 가능성을 향상시키는 .NET Framework가 사용되는 모든 곳에서 사용할 수 있습니다.

  • Windows Forms, WPF 또는 기타 기술을 사용하는 클라이언트 응용 프로그램이나 ASP.NET을 사용하는 서버 응용 프로그램에서 MEF를 사용할 수 있습니다.

  • MEF는 다음과 같이 이식되었습니다. Microsoft.Composition .NET Core에도 부분적으로.

  • System.Composition 이식되고 System.ComponentModel.Composition아직 사용할 수 없습니다. 즉, 디렉터리의 어셈블리에서 형식을로드 할 수있는 카탈로그가 없습니다.

이 장에서는 .NET Core 애플리케이션에서 MEF를 사용하는 방법 만 알아 봅니다.

.NET Core 콘솔 애플리케이션에서 MEF를 사용하는 간단한 예제를 이해하겠습니다. 이제 새 .NET Core 콘솔 프로젝트를 만들어 보겠습니다.

왼쪽 창에서 Templates → Visual C# → .NET Core를 클릭 한 다음 가운데 창에서 콘솔 애플리케이션 (.NET Core)을 선택합니다.

이름 필드에 프로젝트 이름을 입력하고 확인을 클릭하십시오.

프로젝트가 생성되면 MEF를 사용할 수 있도록 Microsoft.Composition의 참조를 추가해야합니다. 이렇게하려면 솔루션 탐색기에서 프로젝트를 마우스 오른쪽 단추로 클릭하고Manage NuGet Packages…

검색 Microsoft.Composition 클릭 Install.

클릭 OK 단추.

클릭 I Accept 단추.

설치가 완료되면 참조에서 오류를 찾을 수 있습니다.

열어 보자 project.json 파일.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
  
   "dependencies": { 
      "Microsoft.Composition": "1.0.30", 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1" 
      } 
   }, 
  
   "frameworks": { 
      "netcoreapp1.0": { 
         "imports": "dnxcore50" 
      } 
   } 
}

당신은 볼 수 있습니다 Microsoft.Composition 종속성이 추가되었지만 문제는이 패키지가 dnxcore50. 그래서 우리는portablenet45+win8+wp8+wpa81. 이제 귀하의project.json 다음 코드로 파일.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
   "dependencies": { 
      "Microsoft.Composition": "1.0.30", 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1"
      } 
   }, 
   "frameworks": { 
      "netcoreapp1.0": { 
         "imports": "portable-net45+win8+wp8+wpa81" 
      } 
   } 
}

이 파일을 저장하면 오류가 수정 된 것을 볼 수 있습니다.

참조를 확장하면 다음에 대한 참조가 표시됩니다. Microsoft.Composition.

먼저 내보낼 인터페이스를 만들고 인터페이스를 구현하고 내보내기 속성으로 클래스를 장식해야합니다. 이제 새 클래스를 추가하겠습니다.

이름 필드에 수업 이름을 입력하고 Add.

다음 코드를 PrintData.cs 파일.

using System; 
using System.Collections.Generic; 
using System.Composition; 
using System.Linq; 
using System.Threading.Tasks; 
  
namespace MEFDemo { 
   public interface IPrintData { 
      void Send(string message); 
   } 
   [Export(typeof(IPrintData))] 
   public class PrintData : IPrintData { 
      public void Send(string message) { 
         Console.WriteLine(message); 
      } 
   } 
}

위에서 언급했듯이 카탈로그는 Microsoft.Composition 네임 스페이스에서 사용할 수 없습니다. 따라서 Program.cs 파일의 Compose 메서드에 표시된대로 내보내기 특성을 사용하여 어셈블리에서 모든 유형을로드하고 가져 오기 특성에 연결합니다.

using System; 
using System.Collections.Generic; 
using System.Composition; 
using System.Composition.Hosting; 
using System.Linq; 
using System.Reflection; 
using System.Threading.Tasks; 
  
namespace MEFDemo { 
   public class Program { 
      public static void Main(string[] args) { 
         Program p = new Program(); 
         p.Run(); 
      } 
      public void Run() { 
         Compose(); 
         PrintData.Send("Hello,this is MEF demo"); 
      } 
      [Import] 
      public IPrintData PrintData { get; set; } 
      
      private void Compose() { 
         var assemblies = new[] { typeof(Program).GetTypeInfo().Assembly }; 
         var configuration = new ContainerConfiguration() 
            .WithAssembly(typeof(Program).GetTypeInfo().Assembly); 
         
         using (var container = configuration.CreateContainer()) { 
            PrintData = container.GetExport<IPrintData>(); 
         } 
      } 
   } 
}

이제 응용 프로그램을 실행 해 보겠습니다. 그러면 응용 프로그램이 PrintData 수업.

MEF에 대해 자세히 알아 보려면 다음 URL을 방문하십시오. https://msdn.microsoft.com/en-us/library/dd460648%28v=vs.110%29.aspx 상세 사항은.