AutoFac使用方法总结:Part I

AutoFac是.net平台下的IOC容器产品,它可以管理类之间的复杂的依赖关系。在使用方面主要是register和resolve两类操作。 这篇文章用单元测试的形式列举了AutoFac的常用使用方法:

注册部分

使用RegisterType进行注册

1
2
3
4
5
6
7
8
9
10
  [Fact]
    public void can_resolve_myclass()
    {
        var builder = new ContainerBuilder();
        builder.RegisterType<MyClass>();

        IContainer container = builder.Build();
        var myClass = container.Resolve<MyClass>();
        Assert.NotNull(myClass);
    }

注册为接口

1
2
3
4
5
6
7
8
9
10
  [Fact]
    public void register_as_interface()
    {
        var builder = new ContainerBuilder();
        builder.Register(c => new MyClass()).As<MyInterface>();

        IContainer container = builder.Build();
        Assert.NotNull(container.Resolve<MyInterface>());
        Assert.Throws(typeof (ComponentNotRegisteredException), () => container.Resolve<MyClass>());
    }

使用lambda表达式进行注册

1
2
3
4
5
6
7
8
9
10
  [Fact]
    public void can_register_with_lambda()
    {
        var builder = new ContainerBuilder();
        builder.Register(c => new MyClass());

        IContainer container = builder.Build();
        var myClass = container.Resolve<MyClass>();
        Assert.NotNull(myClass);
    }

带构造参数的注册

1
2
3
4
5
6
7
8
9
  [Fact]
    public void register_with_parameter()
    {
        var builder = new ContainerBuilder();
        builder.Register(c => new MyParameter());
        builder.Register(c => new MyClass(c.Resolve<MyParameter>()));
        IContainer container = builder.Build();
        Assert.NotNull(container.Resolve<MyClass>());
    }

带属性赋值的注册

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
  [Fact]
    public void register_with_property()
    {
        var builder = new ContainerBuilder();
        builder.Register(c => new MyProperty());
        builder.Register(
            c => new MyClass()
                     {
                         Property = c.Resolve<MyProperty>()
                     });
        IContainer container = builder.Build();
        var myClass = container.Resolve<MyClass>();
        Assert.NotNull(myClass);
        Assert.NotNull(myClass.Property);
    }

Autofac分离了类的创建和使用,这样可以根据输入参数(NamedParameter)动态的选择实现类。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
  [Fact]
    public void select_an_implementer_based_on_parameter_value()
    {
        var builder = new ContainerBuilder();
        builder.Register<IRepository>((c, p) =>
                             {
                                 var type = p.Named<string>("type");
                                 if (type == "test")
                                 {
                                     return new TestRepository();
                                 }
                                 else
                                 {
                                     return new DbRepository();
                                 }
                             }).As<IRepository>();

        IContainer container = builder.Build();
        var repository = container.Resolve<IRepository>(new NamedParameter("type", "test"));
        Assert.Equal(typeof(TestRepository),repository.GetType());
    }

AufoFac也可以用一个实例来注册,比如用在单例模式情况下:

1
2
3
4
5
6
7
8
9
10
  [Fact]
    public void register_with_instance()
    {
        var builder = new ContainerBuilder();
        builder.RegisterInstance(MyInstance.Instance).ExternallyOwned();
        IContainer container = builder.Build();
        var myInstance1 = container.Resolve<MyInstance>();
        var myInstance2 = container.Resolve<MyInstance>();
        Assert.Equal(myInstance1,myInstance2);
    }

注册open generic类型

1
2
3
4
5
6
7
8
9
10
11
  [Fact]
    public void register_open_generic()
    {
        var builder = new ContainerBuilder();
        builder.RegisterGeneric(typeof (MyList<>));
        IContainer container = builder.Build();
        var myIntList = container.Resolve<MyList<int>>();
        Assert.NotNull(myIntList);
        var myStringList = container.Resolve<MyList<string>>();
        Assert.NotNull(myStringList);
    }

对于同一个接口,后面注册的实现会覆盖之前的实现

1
2
3
4
5
6
7
8
9
10
11
  [Fact]
    public void register_order()
    {
        var containerBuilder = new ContainerBuilder();
        containerBuilder.RegisterType<DbRepository>().As<IRepository>();
        containerBuilder.RegisterType<TestRepository>().As<IRepository>();

        IContainer container = containerBuilder.Build();
        var repository = container.Resolve<IRepository>();
        Assert.Equal(typeof(TestRepository), repository.GetType());
    }

如果不想覆盖的话,可以用PreserveExistingDefaults,这样会保留原来注册的实现。

1
2
3
4
5
6
7
8
9
10
11
  [Fact]
    public void register_order_defaults()
    {
        var containerBuilder = new ContainerBuilder();
        containerBuilder.RegisterType<DbRepository>().As<IRepository>();
        containerBuilder.RegisterType<TestRepository>().As<IRepository>().PreserveExistingDefaults();

        IContainer container = containerBuilder.Build();
        var repository = container.Resolve<IRepository>();
        Assert.Equal(typeof (DbRepository), repository.GetType());
    }

可以用Name来区分不同的实现,代替As方法

1
2
3
4
5
6
7
8
9
10
11
12
13
  [Fact]
    public void register_with_name()
    {
        var containerBuilder = new ContainerBuilder();
        containerBuilder.RegisterType<DbRepository>().Named<IRepository>("DB");
        containerBuilder.RegisterType<TestRepository>().Named<IRepository>("Test");

        IContainer container = containerBuilder.Build();
        var dbRepository = container.ResolveNamed<IRepository>("DB");
        var testRepository = container.ResolveNamed<IRepository>("Test");
        Assert.Equal(typeof(DbRepository), dbRepository.GetType());
        Assert.Equal(typeof(TestRepository), testRepository.GetType());
    }

如果一个类有多个构造函数的话,可以在注册时候选择不同的构造函数

1
2
3
4
5
6
7
8
9
10
  [Fact]
    public void choose_constructors()
    {
        var builder = new ContainerBuilder();
        builder.RegisterType<MyParameter>();
        builder.RegisterType<MyClass>().UsingConstructor(typeof (MyParameter));
        IContainer container = builder.Build();
        var myClass = container.Resolve<MyClass>();
        Assert.NotNull(myClass);
    }

AutoFac可以注册一个Assemble下所有的类,当然,也可以根据类型进行筛选

1
2
3
4
5
6
7
8
9
10
11
12
  [Fact]
    public void register_assembly()
    {
        var builder = new ContainerBuilder();
        builder.RegisterAssemblyTypes(Assembly.GetExecutingAssembly()).
            Where(t => t.Name.EndsWith("Repository")).
            AsImplementedInterfaces();

        IContainer container = builder.Build();
        var repository = container.Resolve<IRepository>();
        Assert.NotNull(repository);
    }

Posted by Niu Yi Apr 6th, 2012  c#

原文出处:  http://niuyi.github.io/blog/2012/04/06/autofac-by-unit-test/

时间: 2024-08-26 16:37:18

AutoFac使用方法总结:Part I的相关文章

AutoFac使用方法总结

AutoFac是.net平台下的IOC容器产品,它可以管理类之间的复杂的依赖关系.在使用方面主要是register和resolve两类操作. 这篇文章用单元测试的形式列举了AutoFac的常用使用方法: 注册部分 使用RegisterType进行注册 public void can_resolve_myclass() { var builder = new ContainerBuilder(); builder.RegisterType<MyClass>(); IContainer conta

Autofac 设置方法拦截器的两种方式

前提 1.Nuget安装Autofac 4.0以下版本  4.0及4.0 以上版本暂时没找到合适的方案 2.Nuget安装Autofac.Extras.DynamicProxy2 3.创建一个类似下面代码得 拦截类 public class TestInterceptor : IInterceptor { public void Intercept(IInvocation invocation) { string c = string.Format("Calling method {0} wit

Autofac 依赖注入框架

Autofac是一款IOC框架,比较于其他的IOC框架,如Spring.NET,Unity,Castle等等所包含的,它很轻量级性能上非常高. 官方网站http://autofac.org/ 优点:依赖注入不是目的,它是一系列工具和手段,最终的目的是帮助我们开发出松散耦合(loose coupled).可维护.可测试的代码和程序.这条原则的做法是大家熟知的面向接口,或者说是面向抽象编程. 方法一:注册组件,Register Components var builder = new Contain

一步一步学EF系列【6、IOC 之AutoFac】

前言 之前的前5篇作为EF方面的基础篇,后面我们将使用MVC+EF 并且使用IOC ,Repository,UnitOfWork,DbContext来整体来学习.因为后面要用到IOC,所以本篇先单独先学习一下IOC,我们本本文单独主要学习Autofac,其实对于Autofac我也是边学边记录.不对的地方,也希望大家多多指导. 个人在学习过程中参考博客: AutoFac文档:http://www.cnblogs.com/wolegequ/archive/2012/06/09/2543487.htm

Autofac - 属性注入

属性注入不同于通过构造函数方式传入参数. 这里是通过注入的方式, 在类创建完毕之后, 资源释放之前, 给属性赋值. 这里, 我重新弄一些类来演示这一篇吧. public class ClassA { private readonly ClassB b; public ClassA(ClassB b) { this.b = b; } public void Show() { Console.WriteLine("I am ClassA's instance !"); } } public

Autofac 依赖注入框架 使用

简介 Autofac是一款IOC框架,比较于其他的IOC框架,如Spring.NET,Unity,Castle等等所包含的,它很轻量级性能上非常高. 官方网站http://autofac.org/ 源码下载地址https://github.com/autofac/Autofac 最新版本下载可以看到,包括源码,示例文档,与之相关的测试项目,生成的DLL文件,其他文档 控制反转和依赖注入 关于控制反转和依赖注入的文章和书籍很多,对其定义也解释的也仁者见仁,这里就不赘述了,这是本人(只代表个人观点)

Autofac

Autofac是一款IOC框架,比较于其他的IOC框架,如Spring.NET,Unity,Castle等等所包含的,它很轻量级性能上非常高. 官方网站http://autofac.org/ 源码下载地址https://github.com/autofac/Autofac 控制反转(IoC/Inverse Of Control):   调用者不再创建被调用者的实例,由autofac框架实现(容器创建)所以称为控制反转. 依赖注入(DI/Dependence injection) :   容器创建

asp.net mvc4 简单使用Autofac依赖注入小结

1,首先使用 NuGet下载适当的Autofac版本 文件一,Autofac.3.5.2 文件二,Autofac.Mvc4.3.1.0 1,接口类 public interface IRepository { void GetListCount(); } 2,实现类 public class Repository:IRepository { public void GetListCount() { //return 1; } } 3,控制器 public class HomeController

autofac 注入生命周期

创建实例方法 1.InstancePerDependency 对每一个依赖或每一次调用创建一个新的唯一的实例.这也是默认的创建实例的方式. 官方文档解释:Configure the component so that every dependent component or call to Resolve() gets a new, unique instance (default.) 2.InstancePerLifetimeScope 在一个生命周期域中,每一个依赖或调用创建一个单一的共享的