博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[EnterpriseLibrary]Microsoft.Practices.ObjectBuilder中的定位器Locator
阅读量:5954 次
发布时间:2019-06-19

本文共 1928 字,大约阅读时间需要 6 分钟。

通过对Microsoft.Practices..EnterpriseLibrary学习中发现了一个对象生成器,这个应该是很稳定的一个类库了吧,不然微软应该不会把它封的那么牢固,也没有发现他的源代码。出于学习的目的我用Refrector还原了一下顺便看看里面的来头,从对像浏览器中一看就知道来头不小(注:由于我是刚刚捧这个类库,而且是最新版本的所以没有源代码,和告知,去下载了个2.0地终于发现源码了,在此谢谢他们:)。上网去搜搜阿,功夫不负有心人,终于找到了前人留下的遗产,先看看再说,要真正弄明白我觉得最好的方法就是把代码分离出来看个究竟...
  有关定位器的一些说法可以看看niwalker的《》,他已经讲的很详细了,不过我觉得起初有点蒙,看不懂,后来分离代码后才有点明白其中的道理。从文字上看肯定很累,我们先来看看类关系图,我想那样应该更容易让人明白定位器的原理。
  从上图我们可以看出最原始的一个接口为IReadableLocator,我们把它成为可读定位器接口,所有定位器类都(直接或间接)继承这个接口,他继承两个接口IEnumerable<KeyValuePair<object, object>>, IEnumerable。可读写接口IReadWriteLocator继承IReadableLocator接口,并增加了两个方法Add和Remove就是对其进行追加和移除操作,这样也就形成了可读写的接口了。
  从上图可知,可读定位器的抽象基类当然是继承可读接口,同时对该类进行扩张为可读写的抽象基类,然后分别通过ReadOnlyLocator和Locator实现各自的抽象实例。其中SearchMode具有两个值,分别是Up和Local也就是说Up是可以通过搜索其父容器中的对象,而Local只搜索当前位置。
  最值得让我们注意的是有一个弱引用对象字典WeakRefDictionary,定位器使用它作为内部的存储结构,实现对象的缓冲机制。在分离代码的时候也遇到了一个问题,其中有一个嵌套类是由编译器形成的还是?这个还得研究研究,这里就不丢人了,呵呵,如果有那位高人研究过能否告知小弟:
 1
None.gif [CompilerGenerated]
 2
None.gif
private  
sealed  
class   < GetEnumerator > d__0 : IEnumerator < KeyValuePair < TKey, TValue >> , IEnumerator, IDisposable
 3
ExpandedBlockStart.gif {
 4
InBlock.gif      [DebuggerHidden]
 5
InBlock.gif      
public <GetEnumerator>d__0(
int <>1__state);
 6
InBlock.gif      
private 
bool MoveNext();
 7
InBlock.gif      [DebuggerHidden]
 8
InBlock.gif      
void IEnumerator.Reset();
 9
InBlock.gif      
void IDisposable.Dispose();
10
InBlock.gif
11
ExpandedSubBlockStart.gif      KeyValuePair<TKey, TValue> IEnumerator<KeyValuePair<TKey, TValue>>.Current { [DebuggerHidden] 
get; }
12
ExpandedSubBlockStart.gif      
object IEnumerator.Current { [DebuggerHidden] 
get; }
13
InBlock.gif
14
InBlock.gif      
private 
int <>1__state;
15
InBlock.gif      
private KeyValuePair<TKey, TValue> <>2__current;
16
InBlock.gif      
public WeakRefDictionary<TKey, TValue> <>4__this;
17
InBlock.gif      
public Dictionary<TKey, WeakReference>.Enumerator <>7__wrap3;
18
InBlock.gif      
public 
object <innerValue>5__2;
19
InBlock.gif      
public
 KeyValuePair<TKey, WeakReference> <kvp>5__1;
20
ExpandedBlockEnd.gif}
21
None.gif

  
这种代码以前也米有见过,好像迭代就是这样实现的,可是这种类型对我们好像是不可用的,还得深入研究一下,同时真的希望哪位兄弟能指点指点,真地...其他的实现方法就去看niwalker的《》,写出来也显得多余:)

  上面是通过迭代器yield来完成的!!!!!

本文转自网魂小兵博客园博客,原文链接:http://www.cnblogs.com/xdotnet/archive/2007/01/18/Microsoft_Practices_ObjectBuilder_Locator.html,如需转载请自行联系原作者

你可能感兴趣的文章
RxSwift中Observable的各种创建方法
查看>>
【刘文彬】 Controller:EOS区块链核心控制器
查看>>
大数据开发套件DataIDE使用教程
查看>>
react-navigation使用介绍及UI组件外实现统一跳转
查看>>
RN与原生交互(二)——数据传递
查看>>
程序员必备技能-科学砍需求
查看>>
《记》rxjs分流操作符简单实现
查看>>
阿里开源 iOS 协程开发框架 coobjc源码分析
查看>>
【译】Effective TensorFlow Chapter11——在TensorFlow中调试模型
查看>>
Oracle · 一些实用语法
查看>>
源码阅读:SDWebImage(五)——SDWebImageFrame
查看>>
Webpack 10分钟入门
查看>>
自定义元素探秘及构建可复用组件最佳实践
查看>>
如何做好数据分析师的职业规划?
查看>>
Idea 快捷键
查看>>
如何让pm2支持es6
查看>>
Data Lake Analytics,大数据的ETL神器!
查看>>
解读百度AutoDL:打破SOTA纪录的神经架构搜索是如何炼成的
查看>>
Redis 服务器安装
查看>>
泛型之泛型类
查看>>