微软企业库4.1学习笔记(二十六)Unity依赖注入模块3

  配置运行时支持数组

  

class Foot{ 
public Foot(IBar[] bars) 
{ }
 }
container.Configure<InjectedMembers>()
 .ConfigureInjectionFor<Foot>(
 new InjectionConstructor(new ResolvedArrayParameter<IBar>());
container.Configure<InjectedMembers>() 
    .ConfigureInjectionFor<Foot>
        new InjectionConstructor(
        new ResolvedArrayParameter<IBar>typeof(IBar), new ResolvedParameter<IBar>("some named bar"), new BarImpl()))
 

   运行的时候配置容器

  1、配置构造函数,属性,和方法注入

  你可以在运行的时候,直接创建和加载配之类来配置Unity容器实现注入功能。除去在属性添加attribute和使用配置文件之外,又提供了一种方法。

  使用InjectionConstructor,InjectionProperty和InjectionMethod类联合Configure和ConfigureInjectionFor方法为容器指定依赖注入的参数。

  

IUnityContainer container = new UnityContainer() 
.RegisterType<AType>(new InjectionConstructor()); 
 
AType aType = container.Resolve<AType>(); 
Assert.IsTrue(aType.DefaultConstructorCalled);

   下面的代码示例了如何使用Configuration类配置构造函数注入、属性注入、和方法注入。

IUnityContainer myContainer = new UnityContainer();
 myContainer.Configure<InjectedMembers>() 
.ConfigureInjectionFor<MyObject>(
   new InjectionConstructor(12"Hello Unity!"), 
  new InjectionProperty("MyProperty"), 
  new InjectionProperty("MyStringProperty""SomeText"), 
  new InjectionMethod("InitializeMe"42.0
  new ResolvedParameter(typeof(ILogger), "SpecialLogger")
  ) 
);

  这种API动态配置注入提供了足够的灵活性,保留了简易、直观的使用方式。

  这种配置注入的API是以InjectionParameterValue的子类为基础。当然在建立注入的时候也可以提供其他类型的对象。根据下面的规则,提供的对象将会被翻译成InjectionParameterValue类型。

  1)如果对象是InjectionParameterValue的子类实例的话,注入系统将会使用这个对象。

  2)如果对象是Type的实例,注入系统会创建一个ResolvedParameter作为注入之后返回的类型。

  3)如果是其他对象,配置API会创建一个InjectionParameterValue实例,容器会产生一个属性注入。

  

原文地址:https://www.cnblogs.com/DoNetCShap/p/2295509.html