IOC容器特性注入第二篇:初始引擎查找对应的IOC容器
上篇文章介绍了如何利用反射类查找网站bin文件夹下面所有DLL的程序集类,这篇文章将介绍如何初始化一个IOC容器引擎。
目前IOC容器有很多,如Ninject,Autofac等,每个容器的驱动都不一样,为了方便驱动解耦,好使用不同的IOC容器,就得有一个公共接口。
1. IEngine (引擎接口)
public interface IEngine {
//#region Initialize
//void Initialize();
//#endregion
#region ContainerManager
IContainerManger ContainerManager { get; }
#endregion
#region Resolve
T Resolve<T>(params Parameter[] parameters) where T : class;
T Resolve<T>(string name, params Parameter[] parameters) where T : class;
object Resolve(Type type, params Parameter[] parameters);
object Resolve(Type type, string name, params Parameter[] parameters);
#endregion
#region TryResolve
T TryResolve<T>(params Parameter[] parameters) where T : class;
T TryResolve<T>(string name, params Parameter[] parameters) where T : class;
object TryResolve(Type type, params Parameter[] parameters);
object TryResolve(Type type, string name, params Parameter[] parameters);
#endregion
#region ResolveAll
IEnumerable<Object> ResolveAll(Type serviceType);
IEnumerable<T> ResolveAll<T>();
#endregion
}
接口主要约束:解析,试图解析,解析所有三个方法,都采用实例和泛型两个版本来写。PS:泛型就是实例的约束版而已,但线程是安全的。
2.EngineContext(引擎上下文)
public class EngineContext {
#region Initializtion Methods
/// <summary>
/// 确保方法同步实例化
/// </summary>
/// <param name="forceRecreate"></param>
/// <returns></returns>
[MethodImpl(MethodImplOptions.Synchronized)]
public static IEngine Initialize(bool forceRecreate)
{
if (Singleton<IEngine>.Instance == null || forceRecreate)
{
Singleton<IEngine>.Instance = CreateEngineInstance();
//Singleton<IEngine>.Instance.Initialize();
}
return Singleton<IEngine>.Instance;
}
#endregion
public static IEngine CreateEngineInstance()
{
var typeFinder = new WebAppTypeFinder();
var engines = typeFinder.FindClassesOfType<IEngine>().ToArray();
if (engines.Length > )
{
var defaultEngine =(IEngine)Activator.CreateInstance(engines[]);
return defaultEngine;
}
else
{
throw new ApplicationException("找不到IOC容器");
}
}
public static IEngine Current
{
get
{
if (Singleton<IEngine>.Instance == null)
{
Initialize(false);
}
return Singleton<IEngine>.Instance;
}
}
}
引擎上下文:为了保证系统线程当中可以高性能的使用容器驱动,又是唯一的实例,所以使用单例类进行托管
3.Singleton(单列类)
/// <summary>
/// 单列模式保持唯一性 提高性能
/// </summary>
public class Singleton
{
/// <summary>
/// 字典数组
/// </summary>
private static readonly IDictionary<Type, object> allSingletons; static Singleton()
{
allSingletons=new Dictionary<Type, object>();
} public static IDictionary<Type, object> AllSingletons
{
get
{
return allSingletons;
}
}
}
/// <summary>
/// 单列泛型模式
/// </summary>
/// <typeparam name="T"></typeparam>
public class Singleton<T> : Singleton
{
private static T _instance; public static T Instance
{
get
{
return _instance;
}
set
{
_instance = value;
AllSingletons[typeof (T)] = value;
}
}
} /// <summary>
/// 单列泛型数组模式
/// </summary>
/// <typeparam name="T"></typeparam>
public class SingletonList<T> : Singleton<IList<T>>
{
static SingletonList()
{
Singleton<IList<T>>.Instance=new List<T>();
} public new static IList<T> Instance
{
get
{
return Singleton<IList<T>>.Instance;
}
}
} /// <summary>
/// 单列字典模式
/// </summary>
/// <typeparam name="TKey"></typeparam>
/// <typeparam name="TValue"></typeparam>
public class SingletonDictionary<TKey, TValue> : Singleton<IDictionary<TKey, TValue>>
{
static SingletonDictionary()
{
Singleton<Dictionary<TKey,TValue>>.Instance=new Dictionary<TKey, TValue>();
} public new static IDictionary<TKey, TValue> Instance
{
get
{
return Singleton<Dictionary<TKey, TValue>>.Instance;
}
}
}
单例类:防止重复创建实例。
上面主要是容器接口,上下文等封装,要使用具体的IOC那就得继承IEngine这个接口。
这里使用的是Ninject接口类:
4.NinjectEngine(实现IEngine接口)
public class NinjectEngine:IEngine {
#region Properties
public IContainerManger ContainerManager
{
get;
private set;
}
public ITypeFinder TypeFinder
{
get;
private set;
}
#endregion
#region .ctor
public NinjectEngine(ITypeFinder typeFinder):this(typeFinder,new ContainerManager())
{}
public NinjectEngine(ITypeFinder typeFinder, ContainerManager containerManager)
{
if (typeFinder == null)
{
throw new ArgumentException("没有反射类查找器");
}
this.TypeFinder = typeFinder;
this.ContainerManager = containerManager;
InitializeContainer();
}
#endregion
#region Methods
private void InitializeContainer() {
var attrDependency = new DependencyAttributeRegistrator(this.TypeFinder, this.ContainerManager);
attrDependency.RegisterServices();
}
public T Resolve<T>(params Parameter[] parameters) where T : class
{
return ContainerManager.Resolve<T>(null, parameters);
}
public T Resolve<T>(string name, params Parameter[] parameters) where T : class
{
return ContainerManager.Resolve<T>(name, parameters);
}
public object Resolve(Type type, params Parameter[] parameters)
{
return ContainerManager.Resolve(type, null, parameters);
}
public object Resolve(Type type, string name, params Parameter[] parameters) {
return ContainerManager.Resolve(type, name, parameters);
}
public T TryResolve<T>(params Parameter[] parameters) where T : class
{
return ContainerManager.TryResolve<T>(null, parameters);
}
public T TryResolve<T>(string name, params Parameter[] parameters) where T : class
{
return ContainerManager.TryResolve<T>(name, parameters);
}
public object TryResolve(Type type, params Parameter[] parameters)
{
return ContainerManager.TryResolve(type, null, parameters);
}
public object TryResolve(Type type, string name, params Parameter[] parameters)
{
return ContainerManager.TryResolve(type, name, parameters);
}
public IEnumerable<object> ResolveAll(Type serviceType)
{
return ContainerManager.ResolveAll(serviceType);
}
public IEnumerable<T> ResolveAll<T>()
{
return ContainerManager.ResolveAll<T>();
}
#endregion
}
引擎初始化大致过程是这样的。接口=>程序集查找=>实现接口的IOC容器类=>写入单列=>形成容器驱动上下文
下一篇:
IOC容器特性注入第二篇:初始引擎查找对应的IOC容器的更多相关文章
- IOC容器特性注入第一篇:程序集反射查找
学习kooboo的框架发现它的注入容器方法比较特别,同样是利用MVC的注入点,但它是查找网站下面bin所有的DLL利用反射查找特性找到对应的服务注入到容器. 这样的好处很简单:完全可以不用关心IOC容 ...
- IOC容器特性注入第五篇:查找(Attribute)特性注入
前面几篇文章分别介绍:程序集反射查找,特性,容器,但它们之间贯穿起来,形成查找Attribute注入IOC容器,就得需要下面这个类帮忙: 1.DependencyAttributeRegistrato ...
- IOC容器特性注入第六篇:利用MVC注入点,把容器启动
这里是利用MVC三个注入点中的:IDependencyResolver 进行注入 在全局类中Global.asax代码如下: #region MVC Inject System.Web.Mvc.Dep ...
- IOC容器特性注入第三篇:Attribute封装
Attribute(特性)=>就是对类,方法,字段的自定义属性的基类.可以利用Attribute对类,方法等进行自定义描述,方便区分. 既然如此,那我们就可以那些需要注入IOC容器和不需要注入I ...
- IOC容器特性注入第四篇:容器初始化
IOC容器,就是把各种服务都注入到容器里,想要什么就去拿什么,不仅解决服务类和接口类的耦合度还可以提高性能方便管理. 这里封装一个接口类和一个实现类 1.IContainerManager接口 pub ...
- IOC容器特性注入第七篇:请求上下文作用域
Ninject的对象作用域: Transient .InTransientScope() 每次调用创建新实例. Singleton .InSingletonScope() 单例,仅创建一个实例. Th ...
- Ioc容器依赖注入-Spring 源码系列(2)
Ioc容器依赖注入-Spring 源码系列(2) 目录: Ioc容器beanDefinition-Spring 源码(1) Ioc容器依赖注入-Spring 源码(2) Ioc容器BeanPostPr ...
- Java EE中的容器和注入分析,历史与未来
Java EE中的容器和注入分析,历史与未来 java中的容器 java中的注入 容器和注入的历史和展望 一.java中的容器 java EE中的注入,使我们定义的对象能够获取对资源和其他依赖项的引用 ...
- SSM框架之Spring(2)IOC及依赖注入
Spring(2)IOC及依赖注入 基于xml配置文件的实现 1.IOC (控制反转-Inversion Of Control) 控制反转(Inversion of Control,缩写为IoC),是 ...
随机推荐
- vi 命令 行首、行尾
vim 跳到行首 : 数字 0 vim跳到行位 : $ [Shift + 4]
- eclipse更改workspace中出现The superclass "javax.servlet.http.HttpServlet" was not found on the Java----问题》》
第一步:那是因为在项目中没有告诉它应该在哪个tomcat中运行,右击项目名称----->build path-->configure path---->library------ ...
- window 10系统怎样手动更改电脑的时间
win10系统的电脑显示时间默认的是自动网络校时,也就是电脑的时间跟网络时间同步,那么win10系统怎样手动更改电脑时间呢? 点击电脑左下方的win图标,找到菜单里的[设置] 点击菜单里的[设置],弹 ...
- AngularJS中监视Scope变量以及外部调用Scope方法
在AngularJS中,有时候需要监视Scope中的某个变量,因为变量的改变会影响一些界面元素的显示.有时,也希望通过jQuery调用Scope的某个方法. 比如以下场景: <div> & ...
- mysql 时间类型精确到毫秒、微秒及其处理
一.MySQL 获得毫秒.微秒及对毫秒.微秒的处理 MySQL 较新的版本中(MySQL 6.0.5),也还没有产生微秒的函数,now() 只能精确到秒. MySQL 中也没有存储带有毫秒.微秒的日期 ...
- [Android Pro] 完美解决 No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
原文:https://blog.csdn.net/qq_24118527/article/details/82867864
- 使用JDBC在MySQL数据库中快速批量插入数据
使用JDBC连接MySQL数据库进行数据插入的时候,特别是大批量数据连续插入(10W+),如何提高效率呢? 在JDBC编程接口中Statement 有两个方法特别值得注意: void addBatch ...
- hive行转列
一.问题 hive如何将 a ,, b , c 转化成为: a a a b b c 二.原始数据 cat row_column.txt a ,, b , c 三.解决方案 3.1 遍历每一列 3.1. ...
- WinDbg下载符号文件
设置添加系统环境变量_NT_SYMBOL_PATH 的值为:srv*c:\symbols*http://msdl.microsoft.com/download/symbols 这样启动WinDbg的时 ...
- 书记查询的App设计
表示学习Andriod没有头绪,看书看着看着都觉得大部分是些item的介绍,看过去之后会完全忘记,还是自己做个小东西进行实际开发学习和掌握起来会比较快. PC端的软件已经做好,当然因为PC屏幕较大,手 ...