双向映射 IBidirectionalMapping -- ESBasic 可复用的.NET类库(11)

简介: 1.缘起:     假设我们的用户管理系统要求用户的ID和Name都必须是唯一的,并且用户的ID和Name一经确定就不能被修改。而且管理系统经常需要根据ID来查找Name,也经常需要根据Name来查找ID。

1.缘起:

    假设我们的用户管理系统要求用户的IDName都必须是唯一的,并且用户的IDName一经确定就不能被修改。而且管理系统经常需要根据ID来查找Name,也经常需要根据Name来查找ID。根据这样的需求,我们可以考虑使用一个Dictionary来将IDName缓存起来,通常ID作为KeyName作为Value。这样便可实现通过ID查询Name的快速查找,但是,通过Name查找ID就不是那么快了,因为涉及到对DictionaryValues做遍历的操作。那么,有可能使得通过Name查找ID的速度与通过ID查找Name的速度一样快吗?

    于是,我设计了ESBasic.ObjectManagement.Cache.IBidirectionalMapping(双向映射)来解决这个问题。

      双向映射的形象示意图如下:
      


2.适用场合:

   如果满足以下的条件,则可以使用双向映射:

(1)Key是唯一的,Value也是唯一的。

(2)需要对KeyValue做缓存。

(3)经常需要根据Key来查找Value

(4)经常需要根据Value来查找Key

 

3.设计思想与实现

      IBidirectionalMapping接口定义如下:       

    ///   <summary>
    
///  IBidirectionalMapping 双向映射。即Key和Value都是唯一的,在这种情况下使用IBidirectionalMapping可提升依据Value查找Key的速度。
    
///  该接口的实现必须是线程安全的。2008.08.20
    
///   </summary>     
     public   interface   IBidirectionalMapping < T1, T2 >
    {
        
int  Count {  get ; }

        
///   <summary>
        
///  Add 添加映射对。如果已经有相同的key/value存在,则会覆盖。
        
///   </summary>        
         void  Add(T1 t1, T2 t2);

        
void  RemoveByT1(T1 t1);
        
void  RemoveByT2(T2 t2);

        T1 GetT1(T2 t2);
        T2 GetT2(T1 t1);

        
bool  ContainsT1(T1 t1);
        
bool  ContainsT2(T2 t2);

        
///   <summary>
        
///  GetAllT1ListCopy 返回T1类型元素列表的拷贝。
        
///   </summary>        
         IList < T1 >  GetAllT1ListCopy();

        
///   <summary>
        
///  GetAllT2ListCopy 返回T2类型元素列表的拷贝。
        
///   </summary>     
         IList < T2 >  GetAllT2ListCopy();      
    }

 

 

该接口使用了两个泛型参数,根据上面的描述,一个泛型参数表示Key的类型,另一个泛型参数表示Vlaue的类型。由于,在双向映射中,KeyValue是对称的,所以我没有使用TKeyTValue来命名它们,而是使用T1T2

    在实现BidirectionalMapping时,我们使用两个Dictionary来完成双向映射的功能。一个DictionaryT1KeyT2Value;另一个刚好反过来。

    在实现的具体过程中,要注意以下几点:

(1)为了允许在多线程的环境中使用双向映射,所以BidirectionalMapping必须在对内部Dictionary操作的时候进行加锁控制。

(2)在实现Add方法添加一个“映射对”的时候,必须判断当前是否已经存在了相同的值,如果存在,则先删除旧的映射对,再添加新的映射对。

(3)要注意一个细节,GetAllT1ListCopyGetAllT2ListCopy的实现都使用了lock,这是因为在拷贝的时候会对其KeysValues进行foreach遍历,而在对Dictionary中的元素进行foreach遍历的时候,如果同时向其中添加或删除元素,则foreach操作是会抛出异常的。

 

4. 使用时的注意事项

       BidirectionalMapping提升了通过Name查找ID的速度,这是通过使用了更大的内存来做到的,是典型的“空间换时间”的例子。所以,对于巨大规模的映射对的缓存,要注意内存的使用问题。

     另外,映射对中的两个元素的类型不一定非是IDName这样的简单对象,实际上,非常复杂的对象也可以缓存在双向映射中,只要其GetHashCode方法实现的恰当就不会有任何问题。

 

5.扩展

       双向映射BidirectionalMapping暂时没有任何扩展。

注: ESBasic已经开源,点击这里下载源码。
   
ESBasic开源前言

 

 

目录
相关文章
|
IDE API 开发工具
拦截|篡改|伪造.NET类库中不限于public的类和方法
本文除了回顾拦截.NET类库中的方法,实现方法参数的篡改、方法返回结果的伪造,再着重介绍.NET类库中非public类及方法如何拦截。
拦截|篡改|伪造.NET类库中不限于public的类和方法
|
3月前
|
开发框架 .NET Linux
2款高效的.NET二维码生成类库
2款高效的.NET二维码生成类库
|
3月前
|
XML 开发框架 数据格式
.Net Core 开发框架,支持多版本的类库
.Net Core 开发框架,支持多版本的类库
64 0
|
4月前
|
人工智能 开发框架 Devops
.NET技术概览:** 本文探讨了.NET的核心特性,包括多语言支持、Common Language Runtime、丰富的类库和跨平台能力,强调其在企业级、Web、移动及游戏开发中的应用。
【7月更文挑战第4天】.NET技术概览:** 本文探讨了.NET的核心特性,包括多语言支持、Common Language Runtime、丰富的类库和跨平台能力,强调其在企业级、Web、移动及游戏开发中的应用。此外,讨论了.NET如何通过性能优化、DevOps集成、AI与ML支持以及开源策略应对未来挑战,为开发者提供强大工具,共创软件开发新篇章。
52 3
|
4月前
|
人工智能 前端开发 Devops
NET技术在现代开发中的影响力日益增强,本文聚焦其核心价值,如多语言支持、强大的Visual Studio工具、丰富的类库和跨平台能力。
【7月更文挑战第4天】**.NET技术在现代开发中的影响力日益增强,本文聚焦其核心价值,如多语言支持、强大的Visual Studio工具、丰富的类库和跨平台能力。实际应用涵盖企业系统、Web、移动和游戏开发,以及云服务。面对性能挑战、容器化、AI集成及跨平台竞争,.NET持续创新,开发者应关注技术趋势,提升技能,并参与社区,共同推进技术发展。**
39 1
|
4月前
|
开发框架 .NET API
.NET Core 和 .NET 标准类库项目类型有什么区别?
在 Visual Studio 中,可创建三种类库:.NET Framework、.NET Standard 和 .NET Core。.NET Standard 是规范,确保跨.NET实现的API一致性,适用于代码共享。.NET Framework 用于特定技术,如旧版支持。.NET Core 库允许访问更多API但限制兼容性。选择取决于兼容性和所需API:需要广泛兼容性时用.NET Standard,需要更多API时用.NET Core。.NET Standard 替代了 PCL,促进多平台共享代码。
|
6月前
|
C# 数据安全/隐私保护
一款实用的.NET Core加密解密工具类库
一款实用的.NET Core加密解密工具类库
|
11月前
|
存储 文字识别 C#
一个基于百度飞桨封装的.NET版本OCR工具类库 - PaddleOCRSharp
一个基于百度飞桨封装的.NET版本OCR工具类库 - PaddleOCRSharp
400 0
|
存储 安全 API
10分钟学会Visual Studio将自己创建的类库打包到NuGet进行引用(net,net core,C#)
10分钟学会Visual Studio将自己创建的类库打包到NuGet进行引用(net,net core,C#)
|
XML .NET C#
.NET Framework 类库——C#命名空间大全
引用地址:https://msdn.microsoft.com/zh-cn/library/gg145045.aspx C# using引用时,不知道有哪些命名空间,这下转载收集一篇,方面查找使用。
1180 0

热门文章

最新文章