构建ASP.NET线程安全集合浅析
创始人
2024-04-23 15:01:42
0

大部分ASP.NET线程安全的集合都有一些基础性的缺陷:虽然每个操作都是线程安全的,但是多个操作无法组合起来使用。这意味着一些基本的执行顺序,例如在弹出顶部元素之前检查栈内元素数量会出现潜在的危险。尽管已经有一些API设法将某些操作绑定起来(例如.NET 4的Coordination Data Structures),但是它们往往会引入丑陋的方法(如TryDequeue)。

.NET 1里的集合尝试了另一种方式,它们会对外暴露一个SyncRoot属性,而不是在内部进行锁定。虽然SyncRoot仍然是同步对象的默认机制,但是.NET 2已经抛弃了SyncRoot/Wrapper设计模式。

那么该如何创建一个可用的组合式API呢?Jared Parson认为集合不应该直接暴露出ASP.NET线程安全的API,所有的方法都应该属于一个临时的对象,而这个对象只有在您锁定集合的时候才被创建出来。这个临时对象是集合的“钥匙”,只有钥匙的持有者才能获取集合内容。

以下示例为Jared Parsons的线程安全队列:

  1. static void Example1(ThreadSafeQueue queue) {    
  2.   using (var locked = queue.Lock()) {       
  3.    if (locked.Count > 0) {         
  4.      var first = locked.Dequeue();       
  5.     }    
  6.   }  

名为locked的对象本身不是ASP.NET线程安全的,但是开发人员只有在using代码块中才能正确执行操作。在遵守了这一简单规则之后,开发块里的所有代码就是线程安全的。Jared解释道:

与大部分ASP.NET线程安全的设计一样,这些代码还是有被误用的可能:

1、在ILockedQueue销毁之后却继续使用它。这种做法应该被禁止,用户现有的知识一般足以避免这个问题。此外一些静态检查工具,例如FxCop,会把这种做法识别为一个错误。我们也可以使用一种更严厉的做法来阻止此类情况出现:添加一个disposed标记,并在每个方法中进行检查。

2、如果用户在跨越多个Lock语句的情况下保留某个值(例如Count),那么可能会对集合的状况出现错误的判断和假设。

3、如果用户没有正确销毁ILockedQueue,那么这个对象会被***锁定。幸运的是,对于实现了IDisposable的对象,FxCop同样会将这种做法识别为一个错误——尽管这不是一个万分稳妥的机制。

4、无法确定用户是否会长期持有ILockedQueue对象。虽然IDisposable一般包含着“短期”的意味,但是这并不能做出***的保证。

5、ILockedQueue并不是线程安全的。虽然一般情况下用户不会把IDisposable对象交给多个线程使用,但这也是必须考虑到的情况之一。

构建ASP.NET线程安全集合的相关信息就向你介绍到这里,希望对你有所帮助。

【编辑推荐】

  1. ASP.NET缓存概念及其应用浅析
  2. ASP.NET缓存分析和实践浅析
  3. ASP.NET数据库缓存浅析
  4. ASP.NET源码之自定义控件DateTimePicker
  5. ASP.NET文件下载函数使用浅析

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...