c#集合类的线程安全(整理)
来源:互联网 发布:bing 网络是什么意思 编辑:程序博客网 时间:2024/05/17 04:55
Queue<T> 类
此类型的公共静态(在 Visual Basic 中为 Shared)成员是线程安全的。但不能保证任何实例成员是线程安全的。
只要不修改该集合,Queue<T> 就可以同时支持多个阅读器。即便如此,从头到尾对一个集合进行枚举本质上并不是一个线程安全的过程。
若要确保枚举过程中的线程安全,可以在整个枚举过程中锁定集合。若要允许多个线程访问集合以进行读写操作,则必须实现自己的同步。
System.Collections.Concurrent命名空间提供多个线程安全集合类。当有多个线程并发访问集合时,应使用这些类代替 System.Collections 和System.Collections.Generic 命名空间中的对应类型。
即位于System.Collections命名空间下的集合,如Hashtable,ArrayList,Stack,Queue等.其均提供了线程同步的一个实现
集合线程同步的问题
public class Demo8{ ArrayList list = new ArrayList(1000000); public Demo8() { ThreadPool.QueueUserWorkItem(new WaitCallback(Task1)); ThreadPool.QueueUserWorkItem(new WaitCallback(Task2)); } public void Task1(object obj) { for (int i = 0; i < 500000; i++) { list.Add(i); } Console.WriteLine(DateTime.Now); Console.WriteLine("Task1 count {0}", list.Count); } public void Task2(object obj) { for (int i = 0; i < 500000; i++) { list.Add(i); } Console.WriteLine("Task2 count {0}", list.Count); }}
与预期结果不同
调整为线程同步的集合
每种数据类型都包含一个静态的Synchronized方法,如
ArrayList list = ArrayList.Synchronized(new ArrayList(1000000));
调整后的结果
以下为注意点:
- IsSynchronized判断集合是否为线程同步
- 其内部通过给SyncRoot属性加锁进行同步(即Monitor.Enter)
自己控制锁
public class Demo8{ ArrayList list = new ArrayList(1000000); public Demo8() { ThreadPool.QueueUserWorkItem(new WaitCallback(Task1)); ThreadPool.QueueUserWorkItem(new WaitCallback(Task2)); } public void Task1(object obj) { lock (list.SyncRoot) { for (int i = 0; i < 500000; i++) { list.Add(i); } } Console.WriteLine(DateTime.Now); Console.WriteLine("Task1 count {0}", list.Count); } public void Task2(object obj) { lock (list.SyncRoot) { for (int i = 0; i < 500000; i++) { list.Add(i); } } Console.WriteLine("Task2 count {0}", list.Count); }}
这样的结果显然好看点.内部实现是在Add方法中做锁定.效果自然不是很好.
其他集合类也是类似的操作
参考:
http://www.cnblogs.com/Mainz/archive/2008/04/06/CSharp_HashTable_Dictionary_ArrayList_Threadsafe.html
泛型集合
可以看到原非泛型集合内部的线程同步集合,在每次操作均采用锁操作,但我们并非每个操作都需要锁,比如上面的2个线程操作.只需要2个锁就可以了,但使用内部集合的话则需要锁很多次,带来了性能问题.在.net 2.0泛型集合中,内部不再支持线程同步的集合,即使内部实现了线程同步的集合如List<T>的实现也为开发出来,即把lock的这个操作转嫁给开发者上面了.其实这样反而可以让我们更加了解线程同步的问题,如果真有需要的话,也可以自己实现一个了...
NET Framework 4 中的并行编程9---线程安全集合类
- c#集合类的线程安全(整理)
- c#集合类的线程安全
- c#集合类的线程安全
- c#集合类的线程安全
- c#集合类的线程安全
- c#集合类的线程安全
- C# 中的线程安全集合类
- 线程安全的集合类
- 线程安全的集合类
- 线程安全的集合
- 线程安全的集合
- 线程安全集合类
- Java知识点整理:第十章:包装类、集合的复制、集合线程同步化(线程安全)、集合与数组的相互转换
- 集合框架的线程安全类
- java线程安全的集合类
- 线程安全的并发集合类
- 自定义线程安全的集合类
- java集合框架,线程安全的类
- VC下COM控件使用方法
- JNI中很有用的jstring 与 const char* 的相互转换函数
- c中遍历lua表结构
- hdu 1027
- Ubuntu 给eclipse添加桌面图标
- c#集合类的线程安全(整理)
- 【转载】种子搜索神器下载官网,最新版种子搜索器 p2p bt迅雷种子搜索器
- 淮阴师范CSDN高校俱乐部招贤纳才了!!!
- 扩展方法
- webservice加密,通过SoapHeader来增强Web Service的安全性
- Basic English (基本英语)
- coco2d-x中成员函数回调实现原理
- 英语口语场景-----问路篇
- js正则积累