加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 为什么Collections.Generic.Queue没有Synchronized方法但C

发布时间:2020-12-15 18:02:07 所属栏目:百科 来源:网络整理
导读:System.Collections.Queue类具有 Queue.Synchronized 方法,该方法返回线程安全的Queue实现. 但是通用的System.Collections.Generic.Queue没有Synchronized方法.在这一点上,我有两个问题: 为什么通用的人没有这种方法?它是一个框架API设计决策吗? 从 Queue
System.Collections.Queue类具有 Queue.Synchronized方法,该方法返回线程安全的Queue实现.

但是通用的System.Collections.Generic.Queue没有Synchronized方法.在这一点上,我有两个问题:

>为什么通用的人没有这种方法?它是一个框架API设计决策吗?
>从Queue.Synchronized返回的队列与ConcurrentQueue<T>类不同?

谢谢.

解决方法

Synchronized()方法返回一个包装器队列,该队列绕每个方法锁定一个锁.
在编写多线程应用程序时,此模式实际上并不实用.

大多数现实世界的使用模式都不会对同步集合有益;他们仍然需要锁定更高级别的操作.

因此,System.Collections中的Synchronized()方法实际上是一个引导人们编写非线程安全代码的陷阱.

ConcurrentQueue< T> class专门为并发应用程序设计,包含以原子方式修改队列的有用方法.

并发集合包仅包含在多线程环境中使用的有意义的方法(例如,TryDequeue());它们将指导您编写实际上是线程安全的代码.

这被称为pit of success.

有关更多信息,请参阅my blog

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读