AutoFac使用方法总结:Part I
转自:http://niuyi.github.io/blog/2012/04/06/autofac-by-unit-test/
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#
												
												
								- AutoFac使用方法总结:Part II
		
事件 AutoFac支持三种事件:OnActivating,OnActivated,OnRelease.OnActivating在注册组件使用之前会被调用,此时可以替换实现类或者进行一些其他的初始化工 ...
		 
						- AutoFac使用方法总结:Part I
		
注册部分 使用RegisterType进行注册 [Fact] public void can_resolve_myclass() { var builder = new ContainerBuilde ...
		 
						- AutoFac使用方法总结
		
AutoFac是.net平台下的IOC容器产品,它可以管理类之间的复杂的依赖关系.在使用方面主要是register和resolve两类操作. 这篇文章用单元测试的形式列举了AutoFac的常用使用方法 ...
		 
						- AutoFac使用方法总结四:生命周期续
		
     控制反转(IoC/Inverse Of Control):   调用者不再创建被调用者的实例,由autofac框架实现(容器创建)所以称为控制反转.      依赖注入(DI/Depende ...
		 
						- AutoFac使用方法总结二:事件与依赖循环
		
     事件 AutoFac支持三种事件:OnActivating,OnActivated,OnRelease.OnActivating在注册组件使用之前会被调用,此时可以替换实现类或者进行一些其他 ...
		 
						- AutoFac使用方法总结一:注册
		
AutoFac是.net平台下的IOC容器产品,它可以管理类之间的复杂的依赖关系.在使用方面主要是register和resolve两类操作. 这篇文章用单元测试的形式列举了AutoFac的常用使用方法 ...
		 
						- AutoFac使用方法总结:Part III
		
生命周期 AutoFac中的生命周期概念非常重要,AutoFac也提供了强大的生命周期管理的能力. AutoFac定义了三种生命周期: Per Dependency Single Instance P ...
		 
						- AutoFac使用方法总结三:生命周期
		
     生命周期 AutoFac中的生命周期概念非常重要,AutoFac也提供了强大的生命周期管理的能力.     AutoFac定义了三种生命周期: Per Dependency Single I ...
		 
						- .net core番外第2篇:Autofac的3种依赖注入方式(构造函数注入、属性注入和方法注入),以及在过滤器里面实现依赖注入
		
本篇文章接前一篇,建议可以先看前篇文章,再看本文,会有更好的效果. 前一篇跳转链接:https://www.cnblogs.com/weskynet/p/15046999.html 正文: Autof ...
		 
		
	
随机推荐
	
									- ionic 局部刷新
			
$scope.$on('$ionicView.beforeEnter', console.log("刷新"); })
			 
						- js中拼接html代码时onclick参数问题
			
一.如果是int类型.可以直接传参 二.如果是字符串类型.需要加上引号 1.使用转义符号\转义引号: (\''+strings+'\') 2.使用"  .比如: ("'+strin ...
			 
						- css-两个div并排,左边宽度固定右边自适应的布局 的实现方法
			
<div class= "container"> <div class="left"></div> <div clas ...
			 
						- Python学习记录8-继承2
			
继承 单继承和多继承 单继承:每个类只能继承一个类 多继承:每个类允许继承多个类 >>> class A(): pass >>> class B(A): pass  ...
			 
						- adb使用时出现unanthorized问题
			
adb使用时出现unanthorized问题 ADB 启动时,adb devices出现unanthorized问题. 检查USB调试是否开启. 重新拔插USB数据线是否有授权提示 重启adb :ad ...
			 
						- Linux 下DNS详解
			
配置之前先了解一下bind DNS服务器软件:BIND是一种开源的DNS(Domain Name System)协议的实现,包含对域名的查询和响应所需的所有软件.它是互联网上最广泛使用的一种DNS服务 ...
			 
						- OSI七层与TCP/IP五层
			
OSI七层与TCP/IP五层网络架构详解 OSI和TCP/IP是很基础但又非常重要的网络基础知识,理解得透彻对运维工程师来说非常有帮助.今天偶又复习了一下: (1)OSI七层模型 OSI中的层 功能  ...
			 
						- PAT Basic 1089 狼人杀-简单版 (20 分)
			
以下文字摘自<灵机一动·好玩的数学>:“狼人杀”游戏分为狼人.好人两大阵营.在一局“狼人杀”游戏中,1 号玩家说:“2 号是狼人”,2 号玩家说:“3 号是好人”,3 号玩家说:“4 号是 ...
			 
						- C#readonly和const对比
			
readonly:常量,只能在声明时或构造函数中赋值,与static连用表示静态常量 const:静态常量,只能在声明时赋值
			 
						- JavaScript001,鼠标点击改变文字或图片
			
<h3>我的第一个Javascript</h3> <p id="demo1">1.点击按钮,改变内容!</p> <!-- 设置 ...