总结Unity IOC容器通过配置实现类型映射的几种基本使用方法

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

网上关于Unity IOC容器使用的方法已很多,但未能做一个总结,故我这里总结一下,方便大家选择。

首先讲一下通过代码来进行类型映射,很简单,代码如下:

1
2
3
4
unityContainer =  new  UnityContainer();  //实例化一个容器
 
unityContainer.RegisterType<IClassTest, ClassTest>();  //注册类型映射
unityContainer.Resolve<IClassTest>(); //解析并获取类型的实例

然而实际情况,我们一般不可能直接硬编码在程序中,因为像上述代码上与普通的直接new一个实例并无什么区别,都会存在很明显的依赖,若后面需要更换类,则必需修改程序源码,那就失去了IOC的作用了,所以大多都采用外部配置文件来实现自动映射,下面是我总结的几种配置方法(严格意义来讲,还是一种),供大家选择。

第一种配置如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
< configSections >
   < section  name="unity" type="Microsoft.Practices.Unity.Configuration.UnityConfigurationSection,Microsoft.Practices.Unity.Configuration"/>
</ configSections >
 
< unity >
   < typeAliases >
     < typeAlias   alias="IRepository`1" type="ConsoleApplication1.DDD.Interface.IRepository`1,ConsoleApplication1" />
     < typeAlias   alias="Post" type="ConsoleApplication1.Entities.Post,ConsoleApplication1" />
     < typeAlias   alias="Category" type="ConsoleApplication1.Entities.Category,ConsoleApplication1" />
     < typeAlias   alias="Author" type="ConsoleApplication1.Entities.Author,ConsoleApplication1" />
     < typeAlias   alias="IClassTest" type="ConsoleApplication1.DDD.Interface.IClassTest,ConsoleApplication1" />
   </ typeAliases >
   < container >
     < types >
       < type  type="IRepository[Post]"  mapTo="ConsoleApplication1.DDD.Infrastructure.Repositories.PostRepository,ConsoleApplication1" />
       < type  type="IRepository[Category]"  mapTo="ConsoleApplication1.DDD.Infrastructure.Repositories.CategoryRepository,ConsoleApplication1" />
       < type  type="IRepository[Author]"  mapTo="ConsoleApplication1.DDD.Infrastructure.Repositories.AuthorRepository,ConsoleApplication1" />
       < type  type="IClassTest"  mapTo="ConsoleApplication1.DDD.Interface.ClassTest,ConsoleApplication1" />
     </ types >
   </ container >
</ unity >

 注意配置中的[]方括号表示的是泛型参数,typeAliases->typeAlias中的type及types->type中的mapTo均需配置类型的完整限定名以及类型所在的程序集,中间以逗号分隔,比如:ConsoleApplication1.DDD.Interface.IRepository`1 表示一个IRepository<T>泛型类型,而ConsoleApplication1表示这个泛型所在的程序集,并不是命名空间哦!

第二种配置如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
< configSections >
    < section  name="unity" type="Microsoft.Practices.Unity.Configuration.UnityConfigurationSection,Microsoft.Practices.Unity.Configuration"/>
  </ configSections >
 
< unity >
    < aliases >
      < add   alias="IRepository`1" type="ConsoleApplication1.DDD.Interface.IRepository`1,ConsoleApplication1" />
      < add   alias="Post" type="ConsoleApplication1.Entities.Post,ConsoleApplication1" />
      < add   alias="Category" type="ConsoleApplication1.Entities.Category,ConsoleApplication1" />
      < add   alias="Author" type="ConsoleApplication1.Entities.Author,ConsoleApplication1" />
      < add   alias="IClassTest" type="ConsoleApplication1.DDD.Interface.IClassTest,ConsoleApplication1" />
    </ aliases >
    < container >
      < register  type="IRepository[Post]"  mapTo="ConsoleApplication1.DDD.Infrastructure.Repositories.PostRepository,ConsoleApplication1" />
      < register  type="IRepository[Category]"  mapTo="ConsoleApplication1.DDD.Infrastructure.Repositories.CategoryRepository,ConsoleApplication1" />
      < register  type="IRepository[Author]"  mapTo="ConsoleApplication1.DDD.Infrastructure.Repositories.AuthorRepository,ConsoleApplication1" />
      < register  type="IClassTest"  mapTo="ConsoleApplication1.DDD.Interface.ClassTest,ConsoleApplication1" ></ register >
    </ container >
</ unity >

第三种配置如下(其实是上面两种的简写形式):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
< configSections >
   < section  name="unity" type="Microsoft.Practices.Unity.Configuration.UnityConfigurationSection,Microsoft.Practices.Unity.Configuration"/>
</ configSections >
 
< unity >
   < assembly  name="ConsoleApplication1"></ assembly >
   < namespace  name="ConsoleApplication1.Entities"></ namespace >
   < namespace  name="ConsoleApplication1.DDD.Interface"></ namespace >
   < namespace  name="ConsoleApplication1.DDD.Infrastructure.Repositories"></ namespace >
   < container >
     < register  type="IRepository[Post]"  mapTo="PostRepository" />
     < register  type="IRepository[Category]"  mapTo="CategoryRepository" />
     < register  type="IRepository[Author]"  mapTo="AuthorRepository" />
     < register  type="IClassTest"  mapTo="ClassTest" ></ register >
   </ container >
</ unity >

代码中使用方法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
unityContainer =  new  UnityContainer();
unityContainer.LoadConfiguration(); //如果配置中指定了容器节点的名字name,则需要指定名字
 
unityContainer.Resolve<IRepository<Post>>(); //解析并实例化一个对象
 
 
//以下是采用独立的配置文件(如:unity.config)的使用方法:
             IUnityContainer container =  new  UnityContainer();
             string  configFile =  "Unity.config" ;
             var  fileMap =  new  ExeConfigurationFileMap { ExeConfigFilename = configFile };
             //从config文件中读取配置信息
             Configuration configuration =ConfigurationManager.OpenMappedExeConfiguration(fileMap, ConfigurationUserLevel.None);
             //获取指定名称的配置节
             UnityConfigurationSection section = (UnityConfigurationSection)ConfigurationManager.GetSection( "unity" );
             //载入名称为FirstClass 的container节点
             container.LoadConfiguration(section,  "MyContainer" );

从配置的内容来讲,一看就知道是第三种配置比较的高效与简洁,其实现原理也很简单,就是将需要映射的相关类型的程序集及所在命名空间先全部定义在unity节点中,然后就可以直接配置注册映射,当然上面的配置都很简单,没有包含其它一些属性,比如配置lifetime、constructor等,这些需依据实际情况来配置,在此不作说明,可参考网上其它牛人的教程。

本文转自 梦在旅途 博客园博客,原文链接:http://www.cnblogs.com/zuowj/p/4861594.html  ,如需转载请自行联系原作者

相关文章
|
2天前
|
XML Java 数据格式
Spring容器Bean之XML配置方式
通过对以上内容的掌握,开发人员可以灵活地使用Spring的XML配置方式来管理应用程序的Bean,提高代码的模块化和可维护性。
18 6
|
21天前
|
存储 Prometheus 监控
Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行
本文深入探讨了在Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行。
30 5
|
6月前
|
存储 安全 Linux
Podman入门全指南:安装、配置与运行容器
Podman入门全指南:安装、配置与运行容器
2981 1
|
1月前
|
Kubernetes 监控 Java
如何在Kubernetes中配置镜像和容器的定期垃圾回收
如何在Kubernetes中配置镜像和容器的定期垃圾回收
|
4月前
|
JSON JavaScript 开发者
Composerize神器:自动化转换Docker运行命令至Compose配置,简化容器部署流程
【8月更文挑战第7天】Composerize神器:自动化转换Docker运行命令至Compose配置,简化容器部署流程
Composerize神器:自动化转换Docker运行命令至Compose配置,简化容器部署流程
|
4月前
|
弹性计算 Kubernetes 开发者
利用容器化服务实现游戏服务器的动态资源配置
【8月更文第12天】在游戏行业中,用户基数的变化往往呈现出明显的波动性,特别是在推广活动期间,用户基数会显著增加,而在非推广期则会有所下降。为了应对这种变化,游戏开发者需要一种能够根据用户基数动态调整服务器资源的解决方案,以确保用户体验的同时最大限度地节省成本。容器化服务因其灵活的资源管理和成本控制能力,成为了理想的解决方案。
70 2
|
4月前
|
API 开发工具 vr&ar
PicoVR Unity SDK⭐️一、SDK下载、项目设置与程序初始配置
PicoVR Unity SDK⭐️一、SDK下载、项目设置与程序初始配置
|
3月前
|
vr&ar 图形学 API
Unity与VR控制器交互全解:从基础配置到力反馈应用,多角度提升虚拟现实游戏的真实感与沉浸体验大揭秘
【8月更文挑战第31天】虚拟现实(VR)技术迅猛发展,Unity作为主流游戏开发引擎,支持多种VR硬件并提供丰富的API,尤其在VR控制器交互设计上具备高度灵活性。本文详细介绍了如何在Unity中配置VR支持、设置控制器、实现按钮交互及力反馈,结合碰撞检测和物理引擎提升真实感,助力开发者创造沉浸式体验。
194 0
|
4月前
|
存储 容器
容器镜像解析问题之desc.Image() 方法确定返回的 Image 接口类型如何解决
容器镜像解析问题之desc.Image() 方法确定返回的 Image 接口类型如何解决
23 0
|
4月前
|
Linux 开发工具 数据库
【REP】hrms-ERPNext 容器安装配置
【REP】hrms-ERPNext 容器安装配置
下一篇
DataWorks