IoC容器Autofac(3) - 理解Autofac原理,我实现的部分Autofac功能(附源码)

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介:

上篇文章中,举了一个Autofac的简单例子,园友eflay反应:

“虽然对autofac架构原理还是完全不懂,不过基本是明白ioc的用途了,会从已注册的类中找出符合接口的类来调用构造函数进行构造”

所以这篇文章,还是针对上次的例子,不引用Autofac,完全使用自己写的FakeAutofac, 也让Demo运行起来.

由于本篇文章和以前文章关联度很高,源代码也是从以前的演化过来的。没有看过以前文章的园友,麻烦移步这里, 下载第二篇的源代码,思考一下如何实现例子中Autofac使用到的功能。

IoC容器Autofac(1) -- 什么是IoC以及理解为什么要使用Ioc

IoC容器Autofac(2) - 一个简单示例(附demo源码)

这里是本文相关的源代码 AutofacDem0(1).zip, 源代码主要涉及的知识有反射,泛型,委托。

这篇文章本人没有把握能够把所有的东西都讲的非常浅显易懂, 不过好在有源代码, 代码量不大,加有很多注释,大家可以对比理解一下。

如果对源代码有任何建议和问题,可以留言或者写在评论里,我尽量回复和解答。

 

阅读目录:

一. 开始前的分析

二. 实现过程中遇到的一些难点

三. 总结

一、开始前的分析

我们主要使用到了Autofac中的类和方法:

类ContainerBuilder中的方法:

RegisterType<T>()//注册类型T

AsImplementedInterfaces()//表示注册的类型,以接口的方式注册

Build()//创建一个容器

 

接口IContainer的方法:

Resolve<T>()//从容器中取出一个T类型的实例

 

这里是类图:

二、实现过程中遇到的一些难点

注册类型可以使用集合类来保存,当需要某种类型的实例的时候,可以使用反射调用构造函数直接构造该类型的实例。

这样看起来还蛮简单的,但是还有一些难点, 大家在看源代码的过程中,可以带着这些问题看看是如何解决这些问题的。

1. 如何实现AsImplementedInterfaces()方法?

这个方法的作用是,指定注册类型以接口形式存在, 比如,

当我运行了下面代码后

builder.RegisterType<ListMovieFinder>().AsImplementedInterfaces(); //以类ListMovieFinder的接口IMovieFinder注册

那么我使用 Resolve<IMovieFinder>()要获取一个接口实例的时候,会返回一个ListMovieFinder的实例

 

2. 如何实现对同一个类型的注册,后面的覆盖前面的注册, 如源代码中:

builder.RegisterType<ListMovieFinder>().AsImplementedInterfaces();
builder.RegisterType<DBMovieFinder>().AsImplementedInterfaces();

 后面的DBMovieFinder会覆盖掉ListMovieFinder的注册

这样,当我调用 Resolve<IMovieFinder>()要获取一个接口实例的时候,会返回一个DBMovieFinder的实例

3.当用反射调用构造函数的时候,如果构造函数中有参数,这些参数也由Autofac构造。

比如,当我们Resolve<MPGMovieLister>()想获取MPGMovieLister实例的时候, MPGMovieLister的构造函数需要一个IMovieFinder类型的参数,如何这个参数也由Autofac创建?

 

 三、总结

源代码只是模仿Autofac的一部分功能,只能算是Autofac现有功能中的九牛一毛了。

直接使用别人写好的框架,自然是最简单不过的。 但是通过自己动手写源代码模仿Autofac的实现,自己学到更多,同时写非常感谢那些做开源框架和产品的开发者。

感谢园友eflay, 因为这个,我才有了这个想法,期间几次想放弃写这篇文章,但是"知其然还要知其所以然"的想法又让我坚持了下去。

 

希望源代码和文章能够对大家有所帮助。

本文相关源代码: AutofacDem0(1).zip

相关文章:

IoC容器Autofac(2) - 一个简单示例(附demo源码)

IoC容器Autofac(1) -- 什么是IoC以及理解为什么要使用Ioc

理解为什么要使用Ioc

分析Autofac如何实现Controller的Ioc(Inversion of Control)



本文转自JustRun博客园博客,原文链接:http://www.cnblogs.com/JustRun1983/archive/2013/03/24/2978597.html,如需转载请自行联系原作者


目录
相关文章
|
1月前
|
Java 测试技术 开发工具
ApplicationArguments读取应用程序参数并注入到IOC容器
ApplicationArguments读取应用程序参数并注入到IOC容器
ApplicationArguments读取应用程序参数并注入到IOC容器
|
2月前
|
XML Java 数据格式
Spring IoC容器初始化过程(xml形式)
Spring IoC容器初始化过程(xml形式)
46 0
|
3月前
|
分布式计算 Java Linux
【深入浅出Docker原理及实战】「原理实战体系」零基础+全方位带你学习探索Docker容器开发实战指南(Dockerfile使用手册)
Docker 是一套构建在 Linux 内核之上的高级工具,旨在帮助开发人员和运维人员更轻松地交付应用程序和依赖关系,实现跨系统和跨主机的部署。使用安全且轻量级的容器环境来实现这一目标。容器可以手动创建,也可以通过编写 Dockerfile 自动创建。开发人员和运维人员可以将应用程序及其依赖打包到容器中,实现应用程序的可移植性和环境一致性。
119 5
【深入浅出Docker原理及实战】「原理实战体系」零基础+全方位带你学习探索Docker容器开发实战指南(Dockerfile使用手册)
|
26天前
|
关系型数据库 MySQL Nacos
【深入浅出Nacos原理及调优】「实战开发专题」采用Docker容器进行部署和搭建Nacos服务以及“坑点”
【深入浅出Nacos原理及调优】「实战开发专题」采用Docker容器进行部署和搭建Nacos服务以及“坑点”
47 1
|
1月前
|
存储 前端开发 Java
springboot中的第二个IOC容器BootstrapContext
springboot中的第二个IOC容器BootstrapContext
springboot中的第二个IOC容器BootstrapContext
|
1月前
|
XML Java 数据格式
Spring 的奇幻起源:从 IoC 容器到 Bean 的魔法世界 (下)
Spring 的奇幻起源:从 IoC 容器到 Bean 的魔法世界
|
1月前
|
XML Java 数据格式
Spring 的奇幻起源:从 IoC 容器到 Bean 的魔法世界 (上)
Spring 的奇幻起源:从 IoC 容器到 Bean 的魔法世界 (上)
|
3月前
|
存储 运维 Linux
精彩推荐 | 【深入浅出Docker原理及实战】「原理实战体系」零基础+全方位带你学习探索Docker容器开发实战指南(实战技术总结)
在使用Docker时,管理维护工作可能会显得复杂。然而,实际上,Docker提供了许多便捷且人性化的工具,这些工具的使用技巧可以大大简化维护工作,并提升效率。通过掌握这些技巧,你不仅能够更轻松地管理Docker环境,还能展现出专业的能力。接下来我们就给大家介绍一下对于我在工作当中对于Docker容器使用的技术实战总结
48 2
精彩推荐 | 【深入浅出Docker原理及实战】「原理实战体系」零基础+全方位带你学习探索Docker容器开发实战指南(实战技术总结)
|
3月前
|
存储 运维 Linux
探索容器化技术:Docker的原理与应用
在当今快节奏的软件开发环境中,容器化技术成为了一种重要的工具,其中最为流行和广泛使用的是Docker。本文将深入探讨Docker的原理和使用,包括容器化概念、镜像管理、容器编排等内容,帮助读者更好地理解和应用这项技术。
49 0
|
3月前
|
存储 Linux 开发者
探索容器化技术:揭秘Docker的原理与应用
在当今快节奏的软件开发环境中,容器化技术成为了关键的工具。本文将深入探索Docker作为一种常见的容器化解决方案的原理与使用方法,并讨论其在现代应用开发中的重要性与优势。