快到年终了, 最近项目比较悠闲, 就想总结下, 项目中所使用到的一些技术, 以及使用方法.

之前有写过Dapper以及Dapper的一个扩展, 这些也是项目中使用过的. 算是一个温故而知新吧.

代码:

public interface IAnimal
{
void Say();
} public class Dog : IAnimal
{
public string Name { get; set; }
public void Say()
{
Console.WriteLine("汪汪汪!");
if (!string.IsNullOrEmpty(Name))
{
Console.WriteLine("此汪名叫 " + Name);
}
}
} public class Cat : IAnimal
{
public string Name { get; set; }
public void Say()
{
Console.WriteLine("喵喵喵!");
if (!string.IsNullOrEmpty(Name))
{
Console.WriteLine("此喵名叫 " + Name);
}
}
} public class Person
{
IAnimal adopt; public Person() { } public void Self()
{
Console.WriteLine("我是主人");
} public Person(IAnimal MyPerson)
{
adopt = MyPerson;
} public void Say()
{
Console.WriteLine("我领养了一只小动物");
adopt.Say();
}
}

一、类型注册

类型的注册, 使用的方法是container.Resolve<Type>()和container.Resolve(typeof(Type))两个方法.

示例:

var builder = new ContainerBuilder();

builder.RegisterType<Person>();
builder.RegisterType<Dog>().As<IAnimal>();
builder.RegisterType(typeof(Cat)); var container = builder.Build(); var person = container.Resolve<Person>();
person.Self();
Console.WriteLine("---------");
var animal = container.Resolve<IAnimal>();
animal.Say();
Console.WriteLine("---------");
var cat = container.Resolve<Cat>();
cat.Say();

从图上可以看出, 通过这种方式注册类型之后, 可以正常获取到实例

二、实例注册

示例: (共同部分我就不贴了, 只贴主要部分)

builder.RegisterInstance(new Person(new Dog()));

//-------------------------------------------------
var person = container.Resolve<Person>();
person.Self();
person.Say();

这里还有一种为单例模式准备的实现, 可以把单例托管为容器单例, 我这里就没有写那么多了, 直接上了一个非单例的示例. 也是有效果的哟

builder.RegisterInstance(new Cat()).ExternallyOwned();

//-------------------------------------------------
var cat = container.Resolve<Cat>();
cat.Name = "miao";
cat.Say(); var cat1 = container.Resolve<Cat>();
cat1.Say();

这里我后来试了一下, 就算不加那个, 得到的效果也是单例的效果

三、Lambda方式注册

//builder.RegisterType<Dog>().As<IAnimal>();
builder.Register(c => new Person(c.Resolve<IAnimal>()));
builder.RegisterType<Dog>().As<IAnimal>(); //-------------------------------------------------
var person = container.Resolve<Person>();
person.Say();

IAnimal注册的位置不受限制, 在前面, 在后面, 都是不受影响的, 但是不能没有啊, 没有就会报错了, 程序找不到.

四、程序集注册

这种方式适合懒人用

builder.RegisterAssemblyTypes(Assembly.GetExecutingAssembly()).AsImplementedInterfaces();

//-------------------------------------------------
var animal = container.Resolve<IAnimal>();
animal.Say();

我这里面有两个类实现了IAnimal接口, 但是为什么这里获取到的是cat类, 而不是dog类呢?

五、泛型注册

builder.RegisterGeneric(typeof(List<>)).As(typeof(IList<>)).InstancePerLifetimeScope();
var container = builder.Build();
//-------------------------------------------------
IList<Dog> dogs = container.Resolve<IList<Dog>>();

这里获取到的dogs是一个空的集合, 并不是null值.

六、默认注册

如果一个类, 被多次注册, 会以最后一次注册为准, 就想上面 "四" 出现的情况, 只输出了"喵喵喵", 那是因为Dog类先注册, Cat类后注册, 把之前的覆盖掉了. 注意, 覆盖并不是没有了, 只是不能通过这种方式获取了而已, 还是可以通过别的方式来获取你想要的类的.

先看一下效果:

builder.RegisterType<Dog>().As<IAnimal>();
builder.RegisterType<Cat>().As<IAnimal>(); //-------------------------------------------------
var animal = container.Resolve<IAnimal>();
animal.Say();

如果我想要输出Dog类咋搞呢. 使用 PreserveExistingDefaults(), 这个方法是告诉容器, 这次注册的不是默认输出的.

builder.RegisterType<Dog>().As<IAnimal>();
builder.RegisterType<Cat>().As<IAnimal>().PreserveExistingDefaults();
//-------------------------------------------------
var animal = container.Resolve<IAnimal>();
animal.Say();

那如果想一个接口上注册多个类, 并且都能正常获取呢? 那就看下一篇分解了

参考资料:

Autofac 组件、服务、自动装配 《第二篇》

Autofac文档

Autofac - 组件的更多相关文章

  1. Autofac 组件、服务、自动装配 《第二篇》

    一.组件 创建出来的对象需要从组件中来获取,组件的创建有如下4种(延续第一篇的Demo,仅仅变动所贴出的代码)方式: 1.类型创建RegisterType AutoFac能够通过反射检查一个类型,选择 ...

  2. autofac 组件的实例范围

    实例范围决定如何在请求之间共享服务. 原文地址:http://docs.autofac.org/en/latest/lifetime/instance-scope.html 每个依赖一个实例 使用这个 ...

  3. Autofac 组件、服务、自动装配(2)

    一.组件 创建出来的对象需要从组件中来获取,组件的创建有如下4种(延续第一篇的Demo,仅仅变动所贴出的代码)方式: 1.类型创建RegisterType AutoFac能够通过反射检查一个类型,选择 ...

  4. Autofac 组件、服务、自动装配

    一.组件 创建出来的对象需要从组件中来获取,组件的创建有如下4种(延续第一篇的Demo,仅仅变动所贴出的代码)方式: 1.类型创建RegisterType AutoFac能够通过反射检查一个类型,选择 ...

  5. Autofac官方文档翻译--一、注册组件--4组件扫描

    官方文档:http://docs.autofac.org/en/latest/register/scanning.html Autofac 组件扫描 在程序集中Autofac 可以使用约定来找到并注册 ...

  6. Autofac官方文档翻译--一、注册组件--1注册概念

    官方文档:http://docs.autofac.org/en/latest/register/registration.html 一.注册概念 使用Autofac 注册组件,通过创建一个Contai ...

  7. Autofac - 属性注入

    属性注入不同于通过构造函数方式传入参数. 这里是通过注入的方式, 在类创建完毕之后, 资源释放之前, 给属性赋值. 这里, 我重新弄一些类来演示这一篇吧. public class ClassA { ...

  8. Autofac - 事件

    Autofac在提供之前那些方法的时候, 同时提供了五个事件, 这一篇就看一下这几个事件. 一.五大事件 builder.RegisterType<Person>().As<IPer ...

  9. C#开发微信门户及应用(42)--使用Autofac实现微信接口处理的控制反转处理

    在很多情况下,我们利用IOC控制反转可以很方便实现一些接口的适配处理,可以在需要的时候切换不同的接口实现,使用这种方式在调用的时候,只需要知道相应的接口接口,具体调用哪个实现类,可以在配置文件中动态指 ...

随机推荐

  1. 赴美工作常识(Part 5 - 绿卡优先级)

    这个系列的第一篇<赴美工作常识(Part 1 - 签证)>是三年前写的,过了这么久这个系列终于要继续下去了.接下来当然时讨论绿卡的事情了.跟讨论签证一样,这里必须要有免责声名.因为我不是移 ...

  2. 手把手教你用python打造网易公开课视频下载软件4-图形化界面

    上一篇讲解完函数:def getdownLoadInfo (url): 传入公开课的url地址,就可以提取课程的信息,这一篇讲解一下如何编写图像化界面.大概思考一下图像化界面需要的内容: (1)一个标 ...

  3. openseadragon.js与deep zoom java实现艺术品图片展示

    openseadragon.js 是一款用来做图像缩放的插件,它可以用来做图片展示,做展示的插件很多,也很优秀,但大多数都解决不了图片尺寸过大的问题. 艺术品图像展示就是最简单的例子,展示此类图片一般 ...

  4. springmvc下实现登录验证码功能

    总体思路,简单讲,就是后台生成图片同时将图片信息保存在session,前端显示图片,输入验证码信息后提交表单到后台,取出存放在session里的验证码信息,与表单提交的验证码信息核对. 点击验证码图片 ...

  5. Android中pullToRefresh使用

    pullToRefresh的导入 首先,点击new按钮 -> import Module 然后在 New Module界面选择已经在本地的含有源代码的pullToRefresh. 打开如下图所示 ...

  6. Java-继承,多态0922-05

    28.按要求编写一个Java应用程序: (1)定义一个类,描述一个矩形,包含有长.宽两种属性,和计算面积方法. (2)编写一个类,继承自矩形类,同时该类描述长方体,具有长.宽.高属性, 和计算体积的方 ...

  7. 将不确定变成确定~Uri文本文件不用浏览器自动打开,而是下载到本地

    回到目录 这个标题有点长,简单来说就是,对于一个文件下载来说,是否可以提示用户,让它去保存,而不是将它在浏览器中打开,在浏览器中打开有个致命问题,那就是,如果你的页面编码和文件的编码不一致时,打开的就 ...

  8. H5常用代码:适配方案3

    在H5项目中有一种常见的宣传页,就是那种整屏整屏的,带着炫丽进场动画的移动宣传页,不仅是一种欣赏也起到了很大宣传作用. 对于这种整屏的适配,前面通过视口的兼容处理也是可以做到的,但是在窄屏下会在上下有 ...

  9. Atitit mtp ptp rndis midi协议的不同区别

    Atitit mtp ptp rndis midi协议的不同区别 1. PTP:1 2. MTP:1 3. Mtp 与usb区别2 4. 不过和UMS相比,MTP也有不足之处:3 5.  MTP协议介 ...

  10. cordova 版本

    cordova 版本 npm install cordova@xxxx https://travis-ci.org/apache/cordova-cli https://www.npmjs.com/p ...